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

2025寒假备战蓝桥杯02---朴素二分查找升级版本的学习+分别求解左右端点

文章目录

  • 1.朴素二分查找的升级版
  • 2.查找左端点
  • 3.查找右端点
  • 4.代码的编写

1.朴素二分查找的升级版

和之前介绍的这个二分查找相比,我觉得这个区别就是我们的这个二分查找需要找到的是一个区间,而不是这个区间里面的某一个元素的位置;
image-20250120234321180

2.查找左端点

1)首先就是我们的这个循环的条件:left<right;
2)其次就是我们的判断的这个语句:
x<t,这个t就是我们的target目标值;这个时候和我们的朴素二分一样,就是让这个left=mid+1;
但是当这个x>=t的时候,我们不再是让这个right=mid-1了,而是让这个right=mid,因为这个时候是判断的区间,所以这个mid可能就是我们想要的这个数值;;
3)之前我们确定这个mid的时候是这个+1或者是不+1都是可以的,因为当是偶数的时候,两个情况下对应的这个数值都失败可以帮助我们判断的;
但是在这个里面,我们的终点求解的时候,就应该是这个不加1的版本才可以;

image-20250120235325363

3.查找右端点

1)这个和上面的恰好是反过来的,无论是这个终点的求解,还是这个判断和位置的变换,都是和上面的放过来;
上面的取等号的,我们下面的查找右端点就不用取等号,反之,如果上面没取,我们这个就需要进行相等情况下的判断;
2)其次就是这个里面的终点元素的判断:
left+(right-left+1)/2和上面的也是不同的,上面的是不要+1的;

image-20250120235341957

4.代码的编写

1)首先定义一个数组,里面的两个元素都是-1,这个处理的就是我们的这个示例里面的第三种情况;
2)下面就是分别去查找我们的左端点和右端点,按照上面介绍的这个思路即可;
3)左端点:
left<right作为循环的条件;
mid求解的时候不需要+1的操作;
x<target对应的就是我们的left=mid+1;
x>=target对应的就是我们的mid=right;
return的时候其实这个left和right指向的就是一个位置,因此当我们往数组里面搁置的时候,left和right都是可以的;
image-20250120235648864

4)下面的这个是右端点的判断的逻辑代码:
left<right作为我们的判断的条件;
mid求解的时候需要加上1;
x<=target对应的这个left=mid;
x>target的时候,right=mid减去一;
这个找到端点之后,直接把这个下标放到我们的ret数组里面的第二个元素的位置即可;

image-20250120235816734

http://www.lryc.cn/news/524607.html

相关文章:

  • PHP语言的软件工程
  • linux-FTP服务配置与应用
  • 靠右行驶数学建模分析(2014MCM美赛A题)
  • (1)STM32 USB设备开发-基础知识
  • Spring中如何动态的创建、监听MQ以及创建Exchange
  • 中国综合算力指数(2024年)报告汇总PDF洞察(附原数据表)
  • 【Python项目】小区监控图像拼接系统
  • 常用排序算法之插入排序
  • Elasticsearch(ES)基础查询语法的使用
  • 一篇文章学会Milvus【Docker 中运行 Milvus(Windows),Python实现对Milvus的操作,源代码案例,已经解决巨坑】【程序员猫爪】
  • 前端之移动端
  • 记一次 SpringBoot 启动慢的问题
  • 高效安全文件传输新选择!群晖NAS如何实现无公网IP下的SFTP远程连接
  • 如何在Python中进行JSON数据的序列化和反序列化?
  • 学习记录-统计记录场景下的Redis写请求合并优化实践
  • 网站HTTP改成HTTPS
  • 如何在龙蜥 OS(AliOS)上安装极狐GitLab?
  • unity插件Excel转换Proto插件-ExcelToProtobufferTool
  • C#中的语句
  • 《罗宾逊-旅途VR》Build2108907官方学习版
  • 常用的跨域方案有哪些?
  • JDBC实验测试
  • ChatGPT 摘要,以 ESS 作为你的私有数据存储
  • 每日一题洛谷P2669 [NOIP2015 普及组] 金币c++
  • 【C语言系列】深入理解指针(2)
  • 与 Spring Boot 的无缝集成:ShardingSphere 快速集成实践
  • 【QT】窗口/界面置于最前端显示,且激活该窗口
  • DOL-288 多功能电子计时器说明书
  • 14 常用的负载均衡算法
  • 方法建议ChatGPT提示词分享