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

leetcode35--搜索插入位置--二分查找刷题

搜索插入位置

一共会出现下面四种情况:

目标值在数组所有元素之前
目标值等于数组中某一个元素
目标值插入数组中的位置
目标值在数组所有元素之后

  • 首先在二分查找的代码之前处理掉目标值在数组所有元素之前和之后的情况
  • 如果目标值在数组中的某个位置,正常的二分查找的代码即可处理
  • 所以主要看如何处理[目标值插入数组中的位置]的情况

如果使用while(left<=right)的二分查找的写法,可以发现,数组中没有目标值的时候,最后结束循环的时候,left>right,更准确地说是leftright+1;
而且每次结束循环的时候,mid
right、nums[right]是最接近目标值且小于目标值的一个值。
所以如果要插入到数组中,插入的位置就是left的这个位置。

class Solution {public int searchInsert(int[] nums, int target) {if(target>nums[nums.length-1])return nums.length;if(target<nums[0])return 0;int left=0,right=nums.length-1;while(left<=right){int mid=left+(right-left)/2;if(nums[mid]>target){right=mid-1;}else if(nums[mid]<target){left=mid+1;}else{return mid;}}return left;}
}
http://www.lryc.cn/news/454809.html

相关文章:

  • Django对接支付宝沙箱环境(2024年9月新测有效)
  • 【MySQL】-- 库的操作
  • linux桌面软件(wps)内嵌到主窗口后的关闭问题
  • WindowsTerminal 美化-壁纸随机更换
  • iOS 多次获取图片主题色不一样
  • UE5 武器IK瞄准系统
  • ①EtherCAT转ModbusTCP, EtherCAT/Ethernet/IP/Profinet/ModbusTCP协议互转工业串口网关
  • 在macOS上进行开发环境配置与应用开发详细的配置指南
  • JavaScript 事件处理基础
  • WordPress响应式Git主题响应式CMS主题模板
  • Solidity 设计模式:实现灵活与可扩展的智能合约架构
  • 房屋水电费:重新布局,重构JS代码
  • Jmeter生成JWT token
  • STM32的ADC技术详解
  • PySpark把一列数据上下移动,时序数据
  • 网络基础 【HTTPS】
  • 51单片机的红外感应洗手器【proteus仿真+程序+报告+原理图+演示视频】
  • 【11】纯血鸿蒙HarmonyOS NEXT星河版开发0基础学习笔记-模块化语法与自定义组件
  • Angular 客户端渲染时,从 ng-state 里读取 SSR 状态的具体逻辑
  • C++的联合体union
  • JavaScript 中的变量作用域
  • 【C++】二叉搜索树+变身 = 红黑树
  • 万界星空科技MES数据集成平台
  • Ajax和axios简单用法
  • Chillax2024.08.01 |免费的白噪音软件
  • Python自动化办公:从Excel到PDF生成的全流程
  • allegro 不同页面相同网路的连接
  • 医院管理新趋势:Spring Boot技术引领
  • Java 新手教程!面向对象设计一口气讲完![]~( ̄▽ ̄)~*(中)
  • 驰骋低代码功能升级 - 实体功能权限控制