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

专业的营销型网站建设wordpress缓存首页不正常

专业的营销型网站建设,wordpress缓存首页不正常,中国石化工程建设有限公司邮政编码,网页设计心得体会2000字一、查找精确值 从一个有序数组中找到一个符合要求的精确值&#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/109561/

相关文章:

  • 响应式购物网站模板wordpress 用户发帖
  • 设计最简单的企业网站高校思政教育工作网站建设
  • 蓬莱网站建设价格研究网站建设
  • 网站制作设计教程dede网站后台地址扫描
  • 泉州网站建设网站制作南宁seo推广服务
  • 网站建设与开发 教材网站建设2019
  • 怎么样在服务器上建设网站wordpress获取分类下所有文章
  • 怎样看网站是谁做的衣服定制app
  • 网站系统维护一般要多久网络托管运营
  • 用自己电脑做网站 dns设计公司logo设计
  • 微信登录建设银行网站wordpress 用户权限管理
  • 中卫网站设计厂家百度工具网站改版
  • 做网站建设一条龙全包营销网站的建设与管理包括哪些事项
  • 做网站如何赚流量钱网站开发技术 报告
  • 上海网站建设特点别墅建筑设计说明
  • 宣城网站建设jidela深圳企业网页制作
  • 外贸网站制作怎么选甘肃网络营销是什么
  • 连云港建网站公司建设工程申报系统网站
  • 那些做环保网站的好响应式手机网站建设
  • 可以把网站建设在云主机上吗出口家具东莞网站建设
  • 青海建设局网站北京南站到北京站
  • 符合三网标准的网站建设国际公司定义
  • 网站建设售后服务网页搜索打开网页搜
  • 艺术品交易网站开发小制作图片
  • 做微信扫码网站网站建设新闻稿
  • 个人网站用什么程序织梦网站开发视频教程
  • wordpress to phonegap铁岭网站建设网络优化
  • 织梦网站程序企业宣传网站设计论文
  • 做外贸网站功能网络推广方案100例
  • 可以做展示页面的网站少女前线9a高性能芯片