二分查找也称折半查找(Binary Search),它是一种效率较高的查找方法。但是,折半查找要求线性表必须采用顺序存储结构,而且表中元素按关键字有序排列。
它充分利用了元素间的次序关系,采用分治策略,可在最坏的情况下用O(log n)完成搜索任务。
它的基本思想是:(这里假设数组元素呈升序排列)将n个元素分成个数大致相同的两半,取a[n/2]与欲查找的val作比较,如果x=a[n/2]则找到val,算法终止;如 果val<a[n/2],则我们只要在数组a的左半部继续搜索x;如果val>a[n/2],则我们只要在数组a的右 半部继续搜索val。
下面给出二分查找的两种实现代码:
#include<stdio.h>
int FindValue(int *ar,int n,int val)//循环二分查找
{
int pos = -1;
if(NULL == ar || n < 1) return pos;
int left = 0,right = n - 1;
while(left <= right)
{
int mid = (right - left + 1)/2 + left;
if(val < ar[mid])
{
right = mid - 1;
}else if(val > ar[mid])
{
left = mid + 1;
}
else
{
while(mid > left && val ==