码迷,mamicode.com
首页 > 其他好文 > 详细

[数据结构]二分查找

时间:2015-01-20 21:56:43      阅读:176      评论:0      收藏:0      [点我收藏+]

标签:

1,二分查找:

点击打开链接

 

[cpp] view plaincopy技术分享技术分享
 
  1. int Find(int arr[], int key,int length)  
  2. {  
  3.  assert(arr!=NULL&&length>0);  
  4. int low=0,high=length,mid;  
  5. while(low<=high)  
  6.  {  
  7.  mid=(low+high)/2;  
  8. if(arr[mid]==key) return mid;  
  9. else  
  10.  {  
  11. if(arr[mid]>key) high=mid-1;  
  12. else low=mid+1;  
  13.  }  
  14.  }  
  15. return-1;  
  16. }  


假定集合中油重复的元素,找到某个数首次出现的位置

 

 

[cpp] view plaincopy技术分享技术分享
 
    1. int find(int * arr , int length, int key){  
    2.     int low = 0,high = length-1,mid;  
    3.     while(low <= high){  
    4.         mid = (low + high)/2;  
    5.         if (arr[mid] < key){  
    6.             low = mid + 1;  
    7.         }else if(arr[mid] > key){  
    8.             high = mid - 1;  
    9.         }else{  
    10.             if (mid == 0) return mid;  
    11.             if (mid >= 1 && arr[mid-1] != key) return mid;  
    12.             else high = mid - 1;  
    13.         }  
    14.     }  
    15.     return -1;  
    16. }  

[数据结构]二分查找

标签:

原文地址:http://www.cnblogs.com/zhiliao112/p/4237173.html

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