二分查找算法(非递归)
Posted mnd1024
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了二分查找算法(非递归)相关的知识,希望对你有一定的参考价值。
/**
* @param data 带查找的数组(数组)
* @param target 目标数据
* @return 返回对应的下标,-1 表示没有找到
*/
public static int binarySearch(int[] data, int target) {
int low = 0;
int high = data.length - 1;
// 继续查找
while (high >= low) {
int mid = (low + high) / 2;
if (data[mid] == target) {
return mid;
// 向左边查找
} else if (data[mid] > target) {
high = mid - 1;
//向右边查找
} else if (data[mid] < target) {
low = mid + 1;
}
}
return -1;
}
public static void main(String[] args) {
int[] data = {1,6,8,41,68,100};
System.out.println(binarySearch(data, 100));
}
以上是关于二分查找算法(非递归)的主要内容,如果未能解决你的问题,请参考以下文章