美文网首页
剑指offer-2~4

剑指offer-2~4

作者: IAmWhoAmI | 来源:发表于2016-07-05 11:02 被阅读9次

2.替换空格
请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。

public class Solution {
    public String replaceSpace(StringBuffer str) {
        for(int i=0;i<str.length();i++){
            if(str.charAt(i)==' '){
                str.deleteCharAt(i);
                str.insert(i,"%20");
            }    
        }
        return str.toString();
    }
}
public class Solution {
    public String replaceSpace(StringBuffer str) {
        StringBuilder sb = new StringBuilder();
        int j = 0;
        int i = 0;
        for(;i<str.length();i++){
            if(str.charAt(i)==' '){
                if(j!=i){
                    sb.append(str.subSequence(j, i));
                    sb.append("%20");
                }else{
                    sb.append("%20");
                }
                j=i+1;
            }
        }
        if(j != i){
            sb.append(str.subSequence(j,str.length()));
        }
        return sb.toString();
    }
}

3.从尾到头打印链表
输入一个链表,从尾到头打印链表每个节点的值。

import java.util.ArrayList;
public class Solution {
    public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {
        ArrayList<Integer> res = new ArrayList<Integer>();
        if(listNode == null){
            return res;
        }
        ArrayList<ListNode> listNodes = new ArrayList<ListNode>();
        listNodes.add(listNode);
        while(listNode.next!=null){
                listNode = listNode.next;
                listNodes.add(listNode);
        }
        
        for(int i= listNodes.size()-1;i>=0;i--){
            int item = listNodes.get(i).val;
            res.add(item);
        }
        return res;
    }
}
import java.util.ArrayList;
public class Solution {
    public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {
        ArrayList<Integer> list = new ArrayList<Integer>();
        if(listNode ==null){
            return list;
        }
        while(listNode!=null){
            list.add(0,listNode.val);
            listNode = listNode.next;
        }
        return list;
    }
}

4.重建二叉树
输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。

public class Solution {
    public TreeNode reConstructBinaryTree(int [] pre,int [] in) {
        if(pre.length==0){
            return null;
        }
        return build(pre,in,0,0,pre.length);
    }
    
    public TreeNode build(int[] pre,int[] in,int preStart,int inStart,int size){
        if(size==0){
            return null;
        }
        int nodeVal = pre[preStart];
        TreeNode treeNode = new TreeNode(nodeVal);
        
        int leftSize = 0;
        int rightInStart = inStart;
        for(;leftSize < size;leftSize++,rightInStart++){
            if( in[rightInStart] == nodeVal ){
                rightInStart++;
                break;
            }
        }
        int rightSize = size - leftSize - 1;
            
        treeNode.left  = build( pre , in , preStart + 1 , inStart , leftSize);
        treeNode.right = build( pre , in , preStart + leftSize+1,rightInStart,rightSize);
        return treeNode;
    }
}

相关文章

  • 剑指offer-2~4

    2.替换空格请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过...

  • 剑指week4

    1.二叉搜索树的后序遍历序列 [https://www.acwing.com/problem/content/44...

  • 剑指

    遥望中原九点烟,风云直上七重天。 今朝再向江湖去,一剑流星谁比肩? 2011.10(1488)

  • 剑指

    1. 二维数组中查找 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照...

  • 剑指offer--algorithm4

    在写之前,顺便逛了一下仁兄的主页,受益匪浅,把自己有所感悟的地方摘抄下来,慢慢领悟关于效率--产能和产出 真正的效...

  • 【剑指Offer 4】替换空格

    题目:请实现一个函数,把字符串中的每个空格替换成"%20",例如“We are happy.”,则输出“We%20...

  • 剑指Offer笔试题(4)

    剑指Offer笔试题(3) 题目来源:牛客网 题目一 和为S的连续正数序列 描述: 小明很喜欢数学,有一天他在做...

  • 剑指Offer.C++.code1-5

    剑指offer 代码实现 C++剑指Offer 1. 二维数组中的查找 2. 替换空格 3. 从尾到头打印链表 4...

  • 全网最全剑指offer题目解答

    【剑指offer】Java版代码(完整版) 【剑指offer】1-10题 【剑指offer】11-20题 【剑指o...

  • 剑指offer

    第一题:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,...

网友评论

      本文标题:剑指offer-2~4

      本文链接:https://www.haomeiwen.com/subject/wrshjttx.html