⼆分查找
在⼀个升序的数组中查找指定的数字n,很容易想到的⽅法就是遍历数组,但是这种⽅法效率⽐较低。
⽐如我买了⼀双鞋,你好奇问我多少钱,我说不超过300元。你还是好奇,你想知道到底多少,我就让
你猜,你会怎么猜?你会1,2,3,4...这样猜吗?显然很慢;⼀般你都会猜中间数字,⽐如:150,然
后看⼤了还是⼩了,这就是⼆分查找,也叫折半查找。
#include <stdio.h>
int main()
{
int arr[] = { 1,3,4,6,8,9,10,11,12,13,14,16 };
int sz = sizeof(arr) / sizeof(arr[0]);
int left = 0;
int right = sz - 1;
int key = 0;
scanf("%d", &key);
while (left <= right)
{
int mid = (left + right) / 2;
if (arr[mid] == key)
{
printf("找到了,下标为%d", mid);
break;
}
else if (key < arr[mid])
{
right = mid - 1;
}
else
{
left = mid + 1;
}
}
if (left > right)
{
printf("找不到");
}
return 0;
}
本文介绍了如何在C语言中使用二分查找算法在一个升序数组中查找指定数字,通过模拟猜数字游戏的方式解释了该算法的工作原理和高效性。
1083





