欢迎访问悦橙教程(wld5.com),关注java教程。悦橙教程  java问答|  每日更新
页面导航 : > > 文章正文

java 折半查找,

来源: javaer 分享于  点击 38555 次 点评:130

java 折半查找,


public static void main(String[] args) {
        int[] arr = {0,1,2,3,4,5,6,7,8,9,10};
        System.out.println(halfSearch_2(arr,5));
    }

    public static int halfSearch_1(int[] arr,int key){
        int min = 0,
            max = arr.length-1,
            mid = (min + max)/2;
        while (arr[mid] != key){
            if ( key > arr[mid])
                min = mid+1;
            else if (key < arr[mid])
                max = mid-1;
            if (min>max)
                return -1;
            mid = (min + max)/2;
        }
        return mid;
    }

    public static int halfSearch_2(int[] arr,int key){
        int min = 0,
            max = arr.length-1,
            mid;
        while (min<=max){
            mid = (max+min)>>1;
            if ( key > arr[mid])
                min = mid+1;
            else if (key < arr[mid])
                max = mid-1;
            else
                return mid;
        }
        return -1;
    }

  

相关文章

    暂无相关文章
相关栏目:

用户点评