二分查找算法

Posted m87-a

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了二分查找算法相关的知识,希望对你有一定的参考价值。

/**
* 二分查找算法
* @param args
*/
public static void main(String[] args) {

  int []arr = {1,2,3,4,5,6,7,8,9,10,12,14,15};

  int min = 0;
  int max = arr.length-1;
  int mid = (min + max) / 2;

  int n = 15;

  for (int i = 0; i < arr.length; i++) {
    if(arr[mid] < n) {
      min = mid + 1;
    }else if(arr[mid] > n) {
      max = mid - 1;
    }else {
      System.out.println("查找结果为:"+ arr[mid]+",下表为: "+mid);
      break;
    }
    mid = (max + min) / 2;
  }

}

以上是关于二分查找算法的主要内容,如果未能解决你的问题,请参考以下文章

查找算法之“二分查找”

Go-二分查找算法

算法_001_二分查找算法

每周算法小知识之二分查找

二分算法(java超详细)

细说算法之二分查找算法