【C++】迭代器與二分查詢

風塵_NULL發表於2017-07-26
bool search_value_loop(std::vector <int> &ivec,const int search_value,std::vector <int> ::difference_type & position){
 auto start=ivec.cbegin();
 auto end=ivec.cend();
 auto mid=start+(end-start)/2;
// std::cout<<*mid<<std::endl;
 while(mid!=end && *mid!=search_value){
 if(*mid<search_value){
 start=mid+1;
 }else{
 end=mid-1;
 }
 mid=start +(end-start)/2;
 }
 if(*mid==search_value){
 position=mid-ivec.cbegin()+1;
 return true;
 }
 return false;


}


int main()
{
 bool rest;
 vector <int> ::difference_type position;
 vector <int> ivec={1,2,3,4,18,23,85,122};
 rest=search_value_loop(ivec,122,position);
 if(!rest){
 std::cout<<"no match values"<<std::endl;
 }else{
 std::cout<<position<<std::endl;
 }
}

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/30221425/viewspace-2142580/,如需轉載,請註明出處,否則將追究法律責任。

相關文章