力扣35(java&python)-搜索插入位置(简单)
题目:
给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
请必须使用时间复杂度为 O(log n) 的算法。
示例 1:
输入: nums = [1,3,5,6], target = 5
输出: 2
示例 2:
输入: nums = [1,3,5,6], target = 2
输出: 1
示例 3:
输入: nums = [1,3,5,6], target = 7
输出: 4
提示:
- 1 <= nums.length <= 104
- -104 <= nums[i] <= 104
- nums 为 无重复元素 的 升序 排列数组
- -104 <= target <= 104
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/search-insert-position
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解题思路:
【二分查找】
题目中意思是:如果目标值存在数组中,找到并返回它的索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
那么目标值一定满足:nums[i-1] < target <= nums[i],如果存在目标值,返回的索引为 i ,不存在也返回应该是 i ,因此可以理解为:【在一个有序数组中找到第一个大于等于target的下标】,整体思路为:
- 设定左侧下标left = 0,右侧下标为 right = nums.length - 1;
- 计算中间下标 mid = left + (right - left) / 2(相当于mid = (left + right) /2 或 mid = (left + right) >> 1);
- 根据nums[mid] 和 target所对应的数字大小决定操作,如果相等,直接返回mid,如果target > nums[mid],则mid = left + 1,如果target < nums[mid],则mid = right - 1;
- 查找结束的条件是:left > right,查找结束还没有找到,则直接返回left。
部分操作解释:
1.mid = left + (right - left) / 2,
解:mid = left + (right - left) / 2 = left + 1/2right - 1/2left = 1/2left + 1/2right,这样做是为了防止整型溢出,举个例子,假如现在数值最多到 10,大于10就会溢出了,现在假设left = 6 right = 8;如果现在两个相加再除,6+8 = 14发生溢出了。但是是6 + (8-6)/2 则是6+1 = 7 则不会溢出。我看也有写成:long mid = left + (right - left)/2。
mid = (left + right) >> 1:是将left+right的结果右移一位,位运算右移一位相当于除以2,举个例子:1110(14),右移一位为0111(7)【右移是除,左移是乘】
2.为什么没找到target时返回left?
解:这里只讨论找不到目标值的情况,每次while循环都会使得[left, right]中的元素减少,left左边的元素都是小于target的,right右边的元素都是大于target的,最后一次while循环执行时left=right,执行完毕,left指向的就是第一个大于target的位置,right指向的就是最后一个小于target的位置,例如[3,5],target = 1,首先进入循环取mid=(0+1)/2=0,0位置上的数是3大于target,执行right-1=0,此时right=left=0,再执行最后一次循环, mid = 0, 0位置上的数是3大于target, right- 1 -0, 此时 left > right, 退出循环,退出后left=0,right=-1,故返回left。
java代码:while(left <= right)
1 class Solution {
2 public int searchInsert(int[] nums, int target) {
3 int left = 0, right = nums.length - 1;
4 while(left <= right){
5 int mid = left + (right - left) / 2;
6 if(target > nums[mid]){
7 left = mid + 1;
8 }else if (target < nums[mid]){
9 right = mid - 1;
10 }else{
11 return mid;
12 }
13 }
14 return left;
15 }
16 }

java代码:while(left <right)
1 class Solution {
2 public int searchInsert(int[] nums, int target) {
3 //特殊判断len的位置也有可能是答案
4 if (nums[nums.length - 1] < target) return nums.length;
5 //下面的都满足nums[nums.length - 1] > target
6 int left = 0, right = nums.length - 1;
7 while (left < right){
8 int mid = left + (right - left) / 2;
9 if (nums[mid] >= target){
10 //下一轮搜索区间:[left,mid]
11 right = mid;
12 }else{
13 left = mid + 1;
14 }
15 }
16 //循环结束时:left = right,一定会找到答案返回left
17 return left;
18 }
19 }
python代码:
1 class Solution:
2 def searchInsert(self, nums: List[int], target: int) -> int:
3 left, right = 0, len(nums) - 1
4 while left <= right:
5 mid = left + ((right - left) // 2)
6 if target > nums[mid]:
7 left = mid + 1
8 elif target < nums[mid]:
9 right = mid - 1
10 else:
11 return mid
12 return left

力扣35(java&python)-搜索插入位置(简单)的更多相关文章
- 刷题-力扣-230. 二叉搜索树中第K小的元素
230. 二叉搜索树中第K小的元素 题目链接 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/kth-smallest-element-in-a ...
- LeetCode第35题:搜索插入位置
题目描述: 给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引.如果目标值不存在于数组中,返回它将会被按顺序插入的位置. 你可以假设数组中无重复元素. 示例 1: 输入: [1,3,5,6 ...
- LeetCode(35):搜索插入位置
Easy! 题目描述: 给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引.如果目标值不存在于数组中,返回它将会被按顺序插入的位置. 你可以假设数组中无重复元素. 示例 1: 输入: [1 ...
- Java实现 LeetCode 35 搜索插入位置
35. 搜索插入位置 给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引.如果目标值不存在于数组中,返回它将会被按顺序插入的位置. 你可以假设数组中无重复元素. 示例 1: 输入: [1, ...
- Leetcode 35.搜索插入位置 By Python
给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引.如果目标值不存在于数组中,返回它将会被按顺序插入的位置. 你可以假设数组中无重复元素. 示例 1: 输入: [1,3,5,6], 5 输 ...
- LeetCode(力扣)——Search in Rotated Sorted Array2 搜索旋转排序数组 python实现
题目描述: python实现 Search in Rotated Sorted Array2 搜索旋转排序数组 中文: 假设按照升序排序的数组在预先未知的某个点上进行了旋转. ( 例如,数组 [0 ...
- LeetCode(力扣)——Search in Rotated Sorted Array 搜索旋转排序数组 python实现
题目描述: python实现 Search in Rotated Sorted Array 搜索旋转排序数组 中文:假设按照升序排序的数组在预先未知的某个点上进行了旋转. ( 例如,数组 [0,1 ...
- [leetcode] 35. 搜索插入位置(Java)(二分)
35. 搜索插入位置 二分,太简单,没啥好说的 class Solution { public int searchInsert(int[] nums, int target) { if (nums. ...
- leetcode笔记——35.搜索插入位置 - CrowFea
0.问题描述 给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引.如果目标值不存在于数组中,返回它将会被按顺序插入的位置. 你可以假设数组中无重复元素. 示例 1: 12 输入: [1,3 ...
- Leetcode之二分法专题-35. 搜索插入位置(Search Insert Position)
Leetcode之二分法专题-35. 搜索插入位置(Search Insert Position) 给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引.如果目标值不存在于数组中,返回它将会 ...
随机推荐
- c语言运算符优先级实例解析
壹: 对于优先级:算术运算符 > 关系运算符 > 逻辑运算符 > 赋值运算符.逻辑运算符中"逻辑非 !"除外.这是程序员总结出来的最快的学习方式. 可在实战 ...
- 基于AmbiqMicro-AMA3B2KK-KBR的可穿戴智能手环解决方案之心率测量源码解析
一 前记 梳理该可穿戴产品的手环,产品,是一种成长.也是一个总结. 二 源码解析 1 初始化:这里主要初始化心率的检测间隔时间和心率值的位数. /* initialize heart rate pro ...
- KETTLE4个工作中有用的复杂实例--2、两表数据比较,循环取数据,比较后自动同步(部门、单位数据同步)
附:Kettle实战视频教程,需要的朋友可以看看学习下哈~~ kettle实战第一讲-文件和数据库表的互相转换处理_哔哩哔哩 (゜-゜)つロ 干杯~-bilibili kettle实战第二讲-数据库单 ...
- 编码ascii码,unicode码,utf-8编码
1. ASCII ASCII 只有127个字符,表示英文字母的大小写.数字和一些符号,但由于其他语言用ASCII 编码表示字节不够,例如:常用中文需要两个字节,且不能和ASCII冲突,中国定制了GB2 ...
- 网页端实现Excel转JSON
1. 引言 有时工作中拿到的数据是Excel表格,要在前端网页上使用,通常需要把文件转为JSON 微软的Microsoft Excel没有导出为JSON的功能,其他的第三方网站又不太信任 开源的Exc ...
- RageFrame学习笔记:创建路由+导入layui
这是我写的学习RageFrame的第二篇,这一篇给大家分享下我是如何创建路由,导入外部js,css文件的,这里写下我的全部流程,希望对大家有所帮助. 话不多说,直接开始,在上一章中,我们已经把项目实例 ...
- verilog之wire和reg
verilog之wire和reg 1.区别 wire为线,reg为寄存器.至少初期这两个名词的意思是这样的.wire在电路设计中指代的就是某个点的逻辑值,而reg则指代某个寄存器输出的逻辑值.这个理解 ...
- 关于Dockerfile部署nginx,访问静态资源403Forbidden问题
今天项目遇到一个问题,服务器部署的nginx,在访问静态图片返回403 Forbidden. 容器是采用Dockerfile部署的,代码如下: FROM nginx:latest MAINTAINER ...
- 基于rv1126 rkmeida 一路多出 原理
基于rv1126 rkmeida 一路多出的坑 首先说要的是介绍一下rkmedia 相关内容 RKMedia提供了一种媒体处理方案,可支持应用软件快速开发.RKMedia在各模块基础API上做进一 ...
- 使用POI、JavaCsv工具读取excel文件(*.xls , *.xlsx , *.csv)存入MySQL数据库
首先进行maven的配置:导入相关依赖 1 <dependency> 2 <groupId>org.apache.poi</groupId> 3 <artif ...