循環數組中找查找某個數值

 
 

一、 因爲是有序數組,log(n)的時間查找最小值的indexios

 
 

1.1 必定要注意當m、r、l三個位置相同值時,沒法區分左右了,因此須要在l到r區間遍歷找到最小元素。數組

 
 

二、 看最小值index的左右兩側,是否查找值落在 [l,i] 與 [i,r] 上,在對應區間上進行二分查找spa




1
#include<iostream> 2 using namespace std; 3 int findminpos(int* a, int l, int r){ 4 int pos = l; 5 int min = a[l]; 6 for(int i=l+1; i<=r; i++){ 7 if( min>a[i] ){ 8 min=a[i]; 9 pos=i; 10 } 11 } 12 return pos; 13 } 14 int findBound(int *a, int r){ 15 if ( r==0 ) return 0; 16 int l = 0; 17 while(l<r){ 18 if( r-l == 1 )break; 19 int m = (l+r)>>1; 20 cout << "search at: " << m << endl; 21 if( a[m] == a[r] && a[l] == a[m] ) return findminpos(a,l,r); 22 if( a[m] > a[r] ) l = m; 23 else r = m; 24 } 25 int p = l; 26 if ( a[l] > a[r] ) p = r; 27 return r; 28 } 29 30 bool find(int *a, int s, int arrlen){ 31 if( !a ) return false; 32 int l = 0; 33 int r = arrlen-1; 34 int m = findBound(a, r); 35 cout << "start pos: " << m << endl; 36 if( s >= a[m] && s <= a[r] ) { 37 l = m; 38 } else { 39 r = m-1; 40 } 41 cout << "searching set [" << l << ","<< r << "]" << endl; 42 while ( l <= r ){ 43 m = (l+r)>>1; 44 if( a[m] == s) return true; 45 if( a[m] > s ) r = m-1; 46 else l = m + 1; 47 } 48 return false; 49 } 50 51 int main(){ 52 int a[] = {1,1,1,1,0,1,1}; 53 if(find(a, 1, 7)) { 54 cout << "find" << endl; 55 } else { 56 cout << "not found" << endl; 57 } 58 }
相關文章
相關標籤/搜索