折半查找算法实现

     折半查找是一种比较高效的查找方式,其基本思想是:在某个有序表中,取出中间的记录作为比较对象,如果要查找记录的关键码等于中间记录的关键码,则查找成功;若要查找记录的关键码小于中间记录的关键码,则在中间记录的左半区继续查找;若查找记录的关键码大于中间记录的关键码,则在中间记录的右半区继续查找。不断重复上述查找过程,直到查找成功,或有序表没有所要查找的记录,查找失败。实现过程有两种方式递归法和非递归法。

      1.非递归法:查找成功则返回位置,查找失败则范围-1.

      /////////////////////////////////////////////////
     //非递归查找1. numVec为待查找的集合2.x为待查找数值 3.beg为查找范围起始 4.last为查找范围结束
    /////////////////////////////////////////////////
int Bisearch::BiSearch(vector<int> numVec,int x,int beg,int last){
         int mid;//中间位置
         if(beg>last){ //beg开始位置大于last结束位置,目前只考虑升序状态下
         return -1;
         }  
         while(beg<=last){
               mid =(beg+last)/2; 
               if(x==numVec[mid]){//x(关键码)刚好跟中间值(numVec[mid])相同
               return mid;
         }else if(x>numVec[mid]){//x(关键码)大于中间值(numVec[mid]),起点定位到mid+1
               beg = mid +1;
          }else if(x<numVec[mid]){//x(关键码)小于于中间值(numVec[mid]),终点定位到mid-1
               last = mid -1;
         }
      }
         return -1;
}

           2.递归法:

          int Bisearch::IterBiSearch(vector<int> numVec,int x,int beg,int last){
       //中间位置初始化为-1
       int mid =-1;
       mid = (beg+ last)/2;
       if(x==numVec[mid]){
        return mid;
       }else if(x<numVec[mid]){
             return IterBiSearch(numVec,x,beg,mid-1);
       }else if(x>numVec[mid]){
              return IterBiSearch(numVec,x,mid+1,last);
 }
     return -1;
}

posted on 2014-12-01 21:19  时之刃  阅读(2477)  评论(0编辑  收藏  举报

导航