导航

折半查找/二分查找 以及二叉树的 三种遍历方式

Posted on 2016-10-25 09:09  纵骑横飞zsx  阅读(1450)  评论(0编辑  收藏  举报

     二分查找   线性查找

   1.二分查找

 

public class BinarySearch {
    /**
     * 二分查找
     * @param data
     * @return
     */
    public int binarySearch(long[] data,long n) {
        //左右 端点
        int left =0;
        int right =data.length-1;
        //中间元素
        int mid=-1;
        while(left<right){  // 有两种情况   1.left = right   2.  left>right  错位
            //防绕死代码
            if(mid==(left+right)/2)break;
            //找中间 元素序号
            mid =(left+right)/2;
            if(data[mid]<n){   //说明在 mid右边  这个时候左端点右扩
                left=mid;
            }else if(data[mid]>n){//说明在 mid左边  这个时候右端点右扩
                right=mid;
            }
        }
        //防止发生错位
        if(data[right]==n){
            return right;
        }else if(data[left]==n){
            return left;
        }else if(data[mid]==n){
            return mid;
        }
        return -1;
    }
    public static void main(String[] args) {
        BinarySearch bs=new BinarySearch();
        long[] data={1,3,5,7,9};
        System.out.println(bs.binarySearch(data, 3));
        System.out.println(bs.binarySearch(data,6));

    }
}

 

    2.一棵 二叉树的 遍历方式

    

public class Node {

    //左右节点
    Node right =null;
    Node left =null;
    
    //数据存放
    long data =Long.MAX_VALUE;
    public Node(Node right, Node left, long data) {
        super();
        this.right = right;
        this.left = left;
        this.data = data;
    }
    public Node(long data) {
        this.data=data;
    }
    public Node() {
    }
}
public class BinarySortedTree {
    // 根节点
    Node root = null;

    public boolean add(long data) {
        // 包装一下
        Node n = new Node(data);
        // 判断根节点
        if (root == null)
            root = n;
        else {
            // 当前节点
            Node current = root;
            // 保存父节点
            Node parent = current;

            while (current != null) {
                parent = current;
                if (data > current.data) {
                    // 向左子树查找空位
                    current = current.left;
                } else {
                    // 向右子树查找空位
                    current = current.right;
                }
            }

            // parent不知道 current最后拿的是左子树还是右子树
            if (parent.data < data) {// 说明当时走了左子树
                parent.left = n;
            } else if (parent.data > data) {// 说明当时走了右子树
                parent.right = n;
            }
        }

        return true;
    }


    /**
     *前序遍历
     * 
     * 用迭代的方式 遍历 左 中右
     */
    public void indexNum1(Node temp) {
        //因为 输出根节点总是在 输出 其他节点之前   然后其他节点当做子树根节点遍历 
        System.out.println(temp.data);
        //先走左
        if(temp.left!=null){
            indexNum2(temp.left);
        }
        //再走右子树
        if(temp.right!=null){
            indexNum2(temp.right);
        }
        return ;
        
    }
    
    /**
     *中序遍历
     */
    public void indexNum2(Node temp) {
        if(temp.left!=null){
            indexNum2(temp.left);
        }
        //左子树走到头运行这个 
        System.out.println(temp.data);
        //再走右子树
        if(temp.right!=null){
            indexNum2(temp.right);
        }
        return ;
        
    }
    
    
    
    /**
     *后序遍历
     * 
     * 用迭代的方式 遍历 左 中右
     */
    public void indexNum3(Node temp) {
        if(temp.left!=null){
            indexNum3(temp.left);
        }
        //再走右子树
        if(temp.right!=null){
            indexNum3(temp.right);
        }
        System.out.println(temp.data);
        return ;
        
    }

    public static void main(String[] args) {
        BinarySortedTree bst=new BinarySortedTree();
        bst.add(10);
        bst.add(2);
        bst.add(3);
        bst.add(5);
        
        bst.indexNum3(bst.root);
        
    }

}

 


如果说 想不没明白怎么回事 那就基础 代表的顺序:

    if(有左支)

    indexNum(temp.left);

    syso  //迭代完 左支的 第一句话

    if(有右支)   

     indexNum(temp.right);

 

   这个就是 中序便利