public static boolean BinarySearch(int[] array, int target) {
boolean find = false;
if (array == null || array.length < 1) {
return false;
}
int start = 0;
int end = array.length - 1;
while (start <= end) { // 这里必须是 <= ,很重要
int mid = start + (end - start) / 2;
if (target < array[mid]) {
end = mid - 1;
} else if (target > array[mid]) {
start = mid + 1;
} else {
find = true;
break;
}
}
return find;
}
二分查找
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
推荐阅读更多精彩内容
- 查找概念 查找(Searching): 即根据给定的某个值,在查找表中确定一个其关键字给定值的数据元素(或记录)。...
- 数据结构与算法--查找之顺序查找和二分查找 符号表的目的是将一个键和一个值关联起来,可以将一对键值对插入到符号表中...
- 二分查找二分查找 又称折半查找,要求数组必须是有序的数列,是一种有序查找算法。二分查找的时间复杂度是O(log n...