Java基本算法——二分查找算法

二分查找算法

每次查找取数组中位数的值进行比较
如果目标值值大于中位数的值,则截取中位数右侧的数组再次进行二分查找
如果目标值小于中位数的值,则截取中位数左侧的数组再次进行二分查找
直到找到相对应的中位数才终止查找算法。
即每经过一次比较,查找范围就缩小一半。

while循环实现二分查找

    private static int binSearch(int array[], int value){   int start=0;
        int end =array.length-1;
        int middle;

        while(start<=end){
            middle = (end-start)/2+start;
            if(array[middle] < value){
                start = middle+1;
            }else if (array[middle]>value){
                end = middle-1;
            }else{
                return middle;
            }
        }

        return -1;
    }

递归实现二分查找算法

  private static int binSearch(int array[],int start,int end,int value){
        int middle = (end-start)/2+start;
        if(array[middle]==value){
            return middle;
        }

        if(start>=end){
            return -1;
        } else if (array[middle]>value){
            return binSearch(array,start,middle-1,value);
        }else {
            return binSearch(array,middle+1,end,value);
        }

    }

main方法中调用

    public static void main(String[] args) {
        int array[] ={1,2,3,4,5};
        System.out.println("args = [" + binSearch(array,0,array.length-1,3) + "]");
    }

注意事项

要求进行查找的数组必须是有序数组

你可能感兴趣的:(java)