码迷,mamicode.com
首页 > 编程语言 > 详细

折半查找算法

时间:2014-12-17 12:52:34      阅读:116      评论:0      收藏:0      [点我收藏+]

标签:查找算法   折半查找   二分查找   

/* Date:2014.12.16

    折半查找算法,也叫二分查找,用于对拥有唯一元素的查找。

    需要先经过按序排序后才能进行。只对有序表适用。
*/
//先快速排序:(此处增序,也可降序)
void QuickSort(int *arr,int left,int right)
{
int key,temp,ltemp,rtemp;

ltemp = left;
rtemp = right;
key=arr[(left + right) / 2];

while (ltemp <= rtemp)
{
while (arr[ltemp] < key)
{
ltemp ++;
}
while (key < arr[rtemp])
{
rtemp --;
}
if (ltemp <= rtemp)
{
temp = arr[ltemp];
arr[ltemp] = arr[rtemp];
arr[rtemp] = temp;
ltemp ++;
rtemp --;
}
}

if (left < rtemp)
{
QuickSort(arr,left,rtemp);
}
if (ltemp < right)
{
QuickSort(arr,ltemp,right);

}
//对有序表(有序递增)进行折半查找 

int BinarySearch(int *arr,int n,int x)
{
int low,mid,high;
low = 0;
high = n - 1;
while (low <= high)
{
mid =(low + high) / 2;
if (arr[mid] == x)
{
return mid;

else if (arr[mid] > x)
{
high = mid - 1;
}
else
{
low = mid + 1;
}
}
return -1;
}


bubuko.com,布布扣

折半查找算法

标签:查找算法   折半查找   二分查找   

原文地址:http://blog.csdn.net/sdgtliuwei/article/details/41969219

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!