Binary Search 专栏

Binary Search 时间复杂度 O(logN ), 由于每次减小一半 至关于取logdom

 

Q: 何时能够用Binary Seach?spa

A: 当数据是Sorted 而且支持Random Access的时候code

 

Binary Search 的基本规则blog

1. 搜索空间在循环中不断减少element

 The Searching Area decrease during the processget

2. 目标元素(若是存在)不能够被排除到搜索空间以外 class

 

Basic Binary Search 搜索

 public int binarySearch(int[] array, int target) {
    //Corner case 
    if(array==null || array.length==0){
      return -1;
    }
    int left=0;
    int right=array.length-1;
    while(left<=right){
      int mid=left+(right-left)/2;
      if(array[mid]==target){
        return mid;
      }else if(array[mid]>target){
        right=mid-1;
      }else{
        left=mid+1;
      }
    }
    return -1;
  }

注意几点常见错误 循环

1. int mid=left+(right-left)/2;数据

目的是防止Overflow 

 

2. 注意while 条件的判断 , 如下循环条件排列从苛刻到宽松 

(1).while(left<=right)

留下0个元素

(2).while(left<right)

留下1个元素

(3).while(left<right-1)

留下两个元素 

 

寻找最接近的元素index

 public int closest(int[] array, int target) {
    //Corner case 
    if(array==null || array.length==0){
      return -1;
    }
    int left=0;
    int right=array.length-1;
    while(left<right-1){
      int mid=left+(right-left)/2;
      if(array[mid]==target){
        return mid;
      }else if(array[mid]>target){
        //the right element may be the result
        //cannot be ruled out
        right=mid;
      }else{
        //the left element may be the result
        //cannot be ruled out
        left=mid;
      }
    }
    //Post processing 
    if(target-array[left]<array[right]-target){
      return left;
    }else{
      return right;
    }
  }
相关文章
相关标签/搜索