BinarySearch 二分查找

复杂度分析

时间复杂度
二分搜索每次把搜索区域砍掉一半,很明显时间复杂度为 O\left( \log n \right)。(n代表集合中元素的个数)
空间复杂度
O\left( 1 \right)。虽以递归形式定义,但是 尾递归,可改写为循环。

应用

除直接在一个数组中查找元素外,可用在插入排序中。

//二分查找V0.1实现版
//copyright@2011 July
//随时欢迎读者找bug,email:zhoulei0907@yahoo.cn。
//首先要把握下面几个要点:
//right=n-1 => while(left <= right) => right=middle-1;
//right=n   => while(left <  right) => right=middle;
//middle的计算不能写在while循环外,否则无法得到更新。
int  binary_search( int  array[], int  n, int  value)
{
int  left=0;
int  right=n-1;
//如果这里是int right = n 的话,那么下面有两处地方需要修改,以保证一一对应:
//1、下面循环的条件则是while(left < right)
//2、循环内当array[middle]>value 的时候,right = mid
while  (left<=right)
//循环条件,适时而变
{
int  middle=left + ((right-left)>>1);   //防止溢出,移位也更高效。同时,每次循环都需要更新。
if  (array[middle]>value)
{
      right =middle-1;         //right赋值,适时而变
}
else  if (array[middle]<value)
{
       left=middle+1;
}       
else
return  middle; 
//可能会有读者认为刚开始时就要判断相等,但毕竟数组中不相等的情况更多
//如果每次循环都判断一下是否相等,将耗费时间
}
return  -1;
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值