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

力扣hot100:搜索插入位置

题目描述:

题目分析:

本题是一个二分查找,核心思路是通过计算中心点和目标值的大小关系,以此在一个while循环里不断更新左右端点,知道左端点大于右端点。

代码:

class Solution { public int searchInsert(int[] nums, int target) { int n=nums.length; int right=n-1; int left=0; while(left<=right){ int mid=(right-left)/2+left; if(target>nums[mid]){ left=mid+1; }else{ right=mid-1; } } return left; } }

代码要点分析:

1.中心点的计算为mid=(right-left)/2+left,这样做是为了防止整数溢出。

2.left<=right,若目标值存在于数组中,最后一个可能的leftright是相同的,left < right会错过一些情况。具体来说,在left == right时,依然需要检查这个位置。

3.不必判断target==nums[mid]的情况,在target==nums[mid]时直接把mid更新为right-1,如果后续范围数组里还有target,那么二分查找依旧能查找到范围里的target;如果这已经是最左边的target,那么随后循环里就会出现target>nums[mid]的情况,此时left就会不断右移,知道nums[left]=target。

http://www.gsyq.cn/news/94785.html

相关文章:

  • 提升SEO效率:2025年真正有效的8款AI工具终极清单
  • 实战教程:1小时掌握逆向Unity游戏 (共13课时)
  • 【高可用系统监控的设计原则与实践】
  • 每天一个假设-day5:如何提高测试人员和开发人员的协作效率
  • 视觉色选机:如何挑选技术可靠与服务完善的设备厂家
  • 含SOP配电网重构 关键词:配网重构 yalmip 二阶锥 参考文档:《二阶锥松弛在配电网最优...
  • Labview模拟温度检测报警系统 1、通过设定上下限温度,通过比较温度来到达指示灯的闪烁情况
  • 岐金兰洞见:落地之障,在认知范式,不在技术路径
  • Flutter 测试驱动开发的基本流程
  • Qt关闭主窗体与quit()的深度解析
  • Qt主窗体关闭与quit()的退出机制差异
  • Ubuntu下Qt/C++程序终止全攻略
  • 前期工作总结
  • 智乃的数字【牛客tracker 每日一题】
  • [UUCTF 2022 新生赛]ezpop
  • GitHub中文排行榜终极指南:新手快速发现优质开源项目的完整教程
  • MAUI跨平台云同步终极指南:轻松实现多设备数据无缝流动
  • 3分钟快速上手:WhiteSur主题打造macOS风格Linux桌面完整指南
  • 24
  • GPT-5如何通过新框架减少30%政治偏见
  • 光伏三相并网仿真 模型内容: 1.光伏+MPPT控制+两级式并网逆变器(boost+三相桥式逆...
  • elastic/kibana 升级问题
  • 15、Linux系统管理实用指南
  • 腾讯混元语音驱动数字人技术:重塑动态视频生成新范式
  • SAP业财一体化实现的“隐形桥梁”-价值串
  • 25、技术探索:Google App Engine、Zenoss与Python包管理
  • 5分钟掌握AI驱动飞船设计:用智能参数优化打造专属星际舰队
  • 高中数学
  • 中国独立开发者创业实战指南:从技术到商业的变现路径
  • eHR品牌TOP5年度榜单公布!HR系统/HR管理系统市场主流公司推荐 - 全局中转站