码迷,mamicode.com
首页 > 编程语言 > 详细

二分算法总结

时间:2015-01-04 11:31:06      阅读:152      评论:0      收藏:0      [点我收藏+]

标签:算法   binary search   array   

讨论分为3种,第一种是搜索队列中任意我们需求的结果,第三种我们需求队列中有多个返回第一个,第四种未我们搜索队列中有多个返回最后一个元素的index。

第一种: 在一行排好序队列a中搜索target,一定有。

int binarySearch(int a[],int n, int target)
{
      int start = 0,end = n-1;
      while(start < end){
              mid = start + (end - start)>>1;
              if(a[mid] > target)
                    end = mid - 1;
              else if(a[mid] < target)
                     start = mid + 1;
              else
                      return mid;
     }
     return -1;
}

第二种:在队列多个返回第一个

int binarysearch(int a[],int n,int target)
{
        int start  = 0,end = n-1;
        while(start <= end){
                 mid = start + (end - start)>>1;
                 if(a[mid] >= target)
                       end = mid - 1;
                 else
                       start = mid +  1;
       }
       if(a[start] == target)
                return start;
      else
               return -1;
}

第三种:在队列一个或多个结果返回最后一个结果

int binarysearch(int a[],int n,int target)
{
           int start = 0,end = n-1;
           while(start <= end){
                  mid = start + (end-start)>>1;
                  if(a[mid] > target)
                          end = mid - 1;
                  else
                          start = mid + 1;
          }
          if(a[end] == target)
                  return end;
          else
                   return -1;
}


二分算法总结

标签:算法   binary search   array   

原文地址:http://blog.csdn.net/zcliatb/article/details/42386975

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