您的位置:首页 > 其它

折半查找的迭代与递归实现

2013-12-25 18:01 239 查看
//以此纪念2013年12月18日在百度面试失败,其中写出了二分法的迭代查找却没写出递归查找
#include <stdio.h>
#define LEN 10

int bin_search(int array[], int low, int high, int key);//迭代
int bin_search2(int array[], int low, int high, int key);//递归

int main(){
int arr = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
int key1 = 9,key2 = 3;

printf("key1的位置是 %d\n", bin_search(arr, 0, LEN-1, key1));
printf("key2的位置是 %d\n", bin_search2(arr, 0, LEN-1, key2));
return 0;
}

int bin_search(int array[], int low, int high, int key)
{
int m;
while(low<high){
m = (low + high)/2;
if(array[m]==key){
return m;
}elseif(array[m]>key){
low = m-1;
}else{
high = m+1;
}
}
return -1;
}
int bin_search2(int array[], int low, int high, int key)
{
int m = (low+high)/2;
if(low>high){
return -1;
}
if(array[m]==key){
return m;
}elseif(array[m]>key){
return bin_search2(array, low, m-1, key);
}else{
return bin_search2(array, m+1, high, key);
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: