public class Test2 {
public static void main(String[] args) {
int[] array = new int[]{2, 4, 7, 9, 10, 55, 67};
System.out.println(binarySearch(array, 1));
}
public static int binarySearch(int[] array, int x) {
if (null == array) {
return -1;
}
int begin = 0;
int end = array.length - 1;
while (begin <= end) {
int middle = (begin + end) / 2;
if (array[middle] == x) {
return middle;
} else if (array[middle] > x) {
end = middle - 1;
} else {
begin = middle + 1;
}
}
return -1;
}
}
二分查找
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
推荐阅读更多精彩内容
- 查找概念 查找(Searching): 即根据给定的某个值,在查找表中确定一个其关键字给定值的数据元素(或记录)。...
- 顺序查找是非常简单常用的查找算法,基本思路:从第一个元素m开始逐个与需要查找的元素x进行比较,当比较到元素值相同(...
- 数据结构与算法--查找之顺序查找和二分查找 符号表的目的是将一个键和一个值关联起来,可以将一对键值对插入到符号表中...
- 二分查找二分查找 又称折半查找,要求数组必须是有序的数列,是一种有序查找算法。二分查找的时间复杂度是O(log n...