zoukankan      html  css  js  c++  java
  • 剑指offer第一天

    二维数组中的查找
    数组-二分查找
    1:在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序。请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数
    public boolean Find(int target, int [][] array) {
                //思路:行遍历,对列做二分查找
     
                int i=0;
                while(i<=array.length-1){
                    int left=0;
                    int right=array[0].length-1;
                    int temp=(left+right)/2;
                    while(temp>=left&&temp<=right){
                        if(target<array[i][temp]){
                            right=temp-1;
                        }else if(target>array[i][temp]){
                            left=temp+1;
                        }else if(target==array[i][temp]){
                            return true;
                        }
                        temp=(left+right)/2;
                    }
                    i++;
                }
                return false;  
     
     
    替换空格
    字符串处理
    请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。
    public String replaceSpace(StringBuffer str) {
                //使用String类的replaceAll方法
                return str.toString().replaceAll(" ", "%20");
               //手写思路,首先遍历获取空格数目,然后从后往前插入%20
               
        }
     
    从尾到头打印链表
    单链表逆置-栈的应用
    输入一个链表,按链表值从尾到头的顺序返回一个ArrayList。
     
    /**
    *    public class ListNode {
    *        int val;
    *        ListNode next = null;
    *
    *        ListNode(int val) {
    *            this.val = val;
    *        }
    *    }
    *
    */
    import java.util.ArrayList;
    //利用栈的性质
    //先把listNode存进栈中,再从栈存入ArrayList
     
    import java.util.Stack;
    public class Solution {
        public ArrayList<Integer> printListFromTailToHead(ListNode listNode) {
            ArrayList<Integer> arrayList=new ArrayList<>();
                Stack<Integer> at=new Stack<>();
                
               ListNode p=listNode;
               while(p!=null){
                  at.push(p.val);
                  p=p.next;
               }
               while(!at.isEmpty()){
                   arrayList.add(at.pop());
               }
               return arrayList;
        }
    }
     
    重建二叉树
    二叉树重建-递归
    输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建二叉树并返回。
    /**
    * Definition for binary tree
    * public class TreeNode {
    *     int val;
    *     TreeNode left;
    *     TreeNode right;
    *     TreeNode(int x) { val = x; }
    * }
    */
    public class Solution {
        public TreeNode reConstructBinaryTree(int [] pre,int [] in) {
            
          TreeNode root = fun(pre,0,pre.length - 1,in,0,in.length - 1);
            return root;
            
        }
            //preLeft和preRight为pre的首尾指针
           public static TreeNode fun(int[] pre,int preLeft,int preRight,int[] in,int inLeft,int inRight){
                    //如果首尾指针反向则返回
                   if(preLeft>preRight||inLeft>inRight){
                        return null;
                    }
                   //构造节点,按前序传值
                    TreeNode treeNode=new TreeNode(pre[preLeft]);
                    treeNode.left=null;
                    treeNode.right=null;
                   //找中序位置,建立父与左右子的连接
                    for(int i=0;i<=inRight;i++){
                        //根据先序从前往后找到中序相同值的位置i
                        if(pre[preLeft]==in[i]){
                            //加入左子树,移动首尾指针,pre尾移到,指针in的尾指针到i前面一位
                            //pre的尾指针注意要左移(inleft-i)个位置
                            treeNode.left= fun(pre,preLeft + 1,preRight + i - inLeft,in,inLeft,i - 1);
                          //左边首指针注意右移i-inleft+1个位置
                            treeNode.right= fun(pre,preLeft+ i - inLeft + 1,preRight,in,i + 1,inRight);
                        }
                    }
                    return treeNode;
        }
    }
     
     
  • 相关阅读:
    GeoServer发布PostGIS数据库中的栅格数据
    CMD查看端口占用情况
    css选择器命名推荐
    css书写顺序
    css中浮动相关
    动态规划算法
    KMP算法 字符串匹配
    Java 反射
    分治(Divide-and-Conquer(P))算法
    图 结构
  • 原文地址:https://www.cnblogs.com/yang4869/p/10441583.html
Copyright © 2011-2022 走看看