[关闭]
@RayChen 2016-12-08T17:55:03.000000Z 字数 452 阅读 947

二分查找的基本实现

Ray's logo

关于二分查找法
二分查找法主要是解决在“一堆数中找出指定的数”这类问题。

而想要应用二分查找法,这“一堆数”必须有一下特征:

  • 1,存储在数组中
  • 2,有序排列

所以如果是用链表存储的,就无法在其上应用二分查找法了。

至于是顺序递增排列还是递减排列,数组中是否存在相同的元素都不要紧。不过一般情况,我们还是希望并假设数组是递增排列,数组中的元素互不相同。

二分查找的基本实现

  1. int BinarySearch(int array[], int low, int high, int target)
  2. {
  3. if (low > high || array[high]<target || array[low]>target) return 0;
  4. int mid;
  5. while (high >= low)
  6. {
  7. mid = (low + (high - low) / 2);
  8. if (array[mid] > target) high = mid - 1;
  9. else if (array[mid] < target) low = mid + 1;
  10. else //find the target
  11. return mid;
  12. }
  13. return 0;
  14. }
添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注