二分查找算法的基本思想:
一.首先确定该区间的中间元素位置:mid = (low + high)/2;
mid代表区间内中间元素的位置
low代表区间内最左边元素的位置
high代表区间内最右边元素的位置
二.将待查key元素值与中间元素mid的值(array[mid])比较,如果相等,则查找成功,否则确定新的查找区间。
如果array[mid]>key,则由表的有序性可知,array[mid]右侧的值都大于key,所以等于key的元素如果存在,必然在array[mid]左边的区间中,这时候high = mid- 1;
如果array[mid]<key,则等于key的元素如果存在,必然在array[mid]右边的区间中,这时候low = mid+1;
如果array[mid]=key,则查找成功。
三.如果当前区间查找不存在,则继续重复第一二步骤。
四.在查找过程中,low逐步增加,high逐步减少,如果high<low,则查找失败。
二分法时间复杂度
如果是无序的一组数据,只能用顺序查找时间复杂度O(n),当然我们也可以 先用排序算法让无序变为有序,不过排序的过程也是一个损耗。
如果是有序的一组数据,我们可以直接使用二分查找(也称折半查找),有序也是二分查找的一个基本前提。使用二分的话,假设有1000个数,最坏的情况是要查找(log1000)/(log2)这么多次,所以时间复杂度为O(logn)。
实现代码:
void Binary(int *array,int length,int key){
int low = 0;
int high = length - 1;
int mid = (low + high)/2;
while (low <= high && array[mid] != key) {
if (key > array[mid]) {
low = mid + 1;
} else {
high = mid - 1;
}
mid = (low + high)/2;
}
if (array[mid] == key) {
printf("找到啦!\n");
return;
}
printf("没找到!\n");
return;
}
int main(int argc, const char * argv[]) {
// insert code here...
int a[10] = {1,2,3,4,5,6,7,8,9,10};
Binary(a,10,8);
printf("Hello, World!\n");
return 0;
}