有序表的二分查找和伪代码

  1. int Binary_Search(int *a, int n, int key)  
  2. {  
  3.   int mid = 0;  
  4.   int high = n-1;  
  5.   int low = 0;  
  6.   while (low <= high)  
  7.   {  
  8.       mid = (low+high)/2;  
  9.       if(key < a[mid])  
  10.       {  
  11.           high = mid-1;  
  12.       }  
  13.       else if (key > a[mid])  
  14.       {  
  15.           low = mid+1;  
  16.       }  
  17.       else if (key == a[mid])  
  18.       {  
  19.           return mid;  
  20.       }  
  21.   }  
  22.   return -1;//查找失败  
  23. }  
  24.   
  25. int main()  
  26. {  
  27.     int a[10] = {1,2,3,4,5,6,7,8,9,10};  
  28.     int key = 7;  
  29.     cout<<Binary_Search(a, 10, key)<<endl;  
  30.     key = 99;  
  31.     cout<<Binary_Search(a, 10, key)<<endl;//如果返回-1,则查找失败  
  32.     getchar();  
  33.     return 0;  
  34. }  

伪代码:

BinarySearch(max,min,des)
mid-<(max+min)/2
while(min<=max)
mid=(min+max)/2
if mid=des then
return mid
elseif mid >des then
max=mid-1
else
min=mid+1
return max

posted on 2014-01-06 19:59  小强fly888  阅读(2538)  评论(0)    收藏  举报