当前位置: 首页 > news >正文

网站建设丨金手指排名15厦门网站搜索引擎优化

网站建设丨金手指排名15,厦门网站搜索引擎优化,200万做网站,找客网一、查找精确值 从一个有序数组中找到一个符合要求的精确值&#xff08;如猜数游戏&#xff09;。如查找值为Key的元素下标&#xff0c;不存在返回-1。 //这里是left<right。 //考虑这种情况&#xff1a;如果最后剩下A[i]和A[i1]&#xff08;这也是最容易导致导致死循环的…

一、查找精确值

从一个有序数组中找到一个符合要求的精确值(如猜数游戏)。如查找值为Key的元素下标,不存在返回-1。

//这里是left<=right。
//考虑这种情况:如果最后剩下A[i]和A[i+1](这也是最容易导致导致死循环的情况)首先mid = i,
//如果A[mid] < key,那么left = mid+1 = i +1,如果是小于号,则A[i + 1]不会被检查,导致错误
int left = 1,right = n;
while(left <= right)
{//这里left和right代表的是数组下标,所有没有必要改写成mid = left + (right - left)/2;//因为当代表数组下标的时候,在数值越界之前,内存可能就已经越界了//如果left和right代表的是一个整数,就有必要使用后面一种写法防止整数越界int mid = (left + right) / 2;if(A[mid] == key)return mid;else if(A[mid] > key)//这里因为mid不可能是答案了,所以搜索范围都需要将mid排除right = mid - 1;elseleft = mid + 1;
}
return -1;

二、查找大于等于/大于key的第一个元素

这种通常题目描述为满足某种情况的最小的元素。

int left = 1,right = n;
while(left < right)
{//这里不需要加1。我们考虑如下的情况,最后只剩下A[i],A[i + 1]。//首先mid = i,如果A[mid] > key,那么right = left = i,跳出循环,如果A[mid] < key,left = right = i + 1跳出循环,所有不会死循环。int mid = (left + right) / 2;if(A[mid] > key)//如果要求大于等于可以加上等于,也可以是check(A[mid])right = mid;//因为找的是大于key的第一个元素,那么比A[mid]大的元素肯定不是第一个大于key的元素,因为A[mid]已经大于key了,所以把mid+1到后面的排除elseleft = mid + 1;//如果A[mid]小于key的话,那么A[mid]以及比A[mid]小的数都需要排除,因为他们都小于key。不可能是第一个大于等于key的元素,
}

三、查找小于等于/小于key的最后一个元素

这种通常题目描述为满足某种情况的最大的元素。如Leetcode69题,求sqrt(x)向下取整就是这种模板。

int left = 1, right = n;
while(left < right)
{//这里mid = (left + right + 1) / 2;//考虑如下一种情况,最后只剩下A[i],A[i + 1],如果不加1,那么mid = i,如果A[mid] < key,执行更新操作后,left = mid,right = mid + 1,就会是死循环。//加上1后,mid = i + 1,如果A[mid] < key,那么left = right = mid + 1,跳出循环。如果A[mid] > key,left = mid = i,跳出循环。int mid = (left + right + 1) / 2;if(A[mid] < key)left = mid;//如果A[mid]小于key,说明比A[mid]更小的数肯定不是小于key的最大的元素了,所以要排除mid之前的所有元素elseright = mid - 1;//如果A[mid]大于key,那么说明A[mid]以及比A[mid]还要大的数都不可能小于key,所以排除A[mid]及其之后的元素。
}

四、总结

最后两种情况的循环跳出条件是left<right,为什么不是小于等于呢?因为我们的区间变换思路是不断的舍去不可能是解的区间,最后只剩下一个数就是我们的解。而第一种情况就算最后只剩一个数也有可能不是解,所以需要使用小于等于。

  • 查找精确值,循环条件是小于等于;查找满足情况的最大最小值,循环条件是小于。
  • 查找满足条件的最大数,mid = (right + left + 1) / 2;查找满足条件的最小数,mid = (right + left)/2
  • mid = left + (right - left) / 2,不是适用于所有的情况。
  • 如果存在没有解的情况,比如从[1,2,3,4,5]找出大于等于6的第一个数,我们只需要将最后剩下的数单独进行一次判断就可以了。

作者:T-SHLoRk
链接:https://www.acwing.com/blog/content/307/
来源:AcWing
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

http://www.yayakq.cn/news/570224/

相关文章:

  • 其中网站的功能需要电气工程师报考条件
  • 在哪里查网站是什么时候建站怎样自己做商场网站
  • 民兵信息化网站建设用ipv6地址做网站访问
  • 网站充值支付宝收款怎么做网络营销工具和方法
  • 建设网站分析报告公司如何申请一个网站网址
  • 零食天堂 专做零食推荐的网站网站建设与管理需要什么软件有哪些内容
  • 凡科网做网站怎么样济南网站建设有限公司
  • 四川网站建设贴吧天津大良网站建设
  • 政务网站系统力天装饰工程有限公司
  • 国外炫酷网站给公司做网站费用
  • p2p信贷网站建设宣传广告设计图片
  • 网站二次开发费用广告优化师工作内容
  • 网站首页制作的过程如何给网站做301重定向
  • 购物网站开发技术网站开发入门书籍2018
  • 网站建设技术网站新站突然网站停止收录
  • 门户网站的特点和优势正在跳转页面
  • 杭州市富阳区建设局网站广东省农业农村厅班子
  • 惠州+企业网站建设重庆最新消息今天
  • 免费做优化的网站建设做个小程序多少钱
  • 网站服务器管理系统WordPress 短码转换
  • 天津建设工程网站网站如何做才会有流量
  • 网站搭建介绍省水利工程建设信息网站
  • 网站制作视频教程全wordpress mc
  • 网站开发维护工作抖音小程序开发教程
  • 手机免费建设网站深圳响应式网页设计
  • 建设用地规划许可证在哪个网站查询泰安可信的网站建设
  • 网站备案接入商是什么济南网站制作哪家专业
  • 靖江市网站建设网站建网站建设网站
  • 爱是做的电影网站吗郑州居家办公全员核酸
  • 做课题的网站有多少是备案的seo网站管理招聘