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

搜索插入位置

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

目标值在数组所有元素之前

目标值等于数组中某一个元素

目标值插入数组中的位置

目标值在数组所有元素之后

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

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

所以如果要插入到数组中,插入的位置就是left的这个位置。

java 复制代码
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;
    }
}
相关推荐
睡觉就不困鸭41 分钟前
第十八天 有效的括号
数据结构·算法
浅念-1 小时前
分治算法专题|LeetCode高频经典题目详细题解
数据结构·c++·算法·leetcode·职场和发展·排序·分治
Irissgwe2 小时前
优选算法精讲(专题一)
数据结构·算法
睡觉就不困鸭2 小时前
第十五天 反转字符串
数据结构·算法
并不喜欢吃鱼2 小时前
从零开始C++----九【C++ 数据结构】搜索二叉树(BST)全解析:从定义到实现,一篇搞定
数据结构
如君愿2 小时前
考研复习 Day 18 | 数据结构与算法--图(上)
数据结构·考研·记录考研
自我意识的多元宇宙3 小时前
【数据结构】平衡二叉树
数据结构
睡觉就不困鸭3 小时前
第十六天 反转字符串II
数据结构
测绘第一深情3 小时前
租用GPU云服务器进行深度学习(AutoDL,超保姆级,适用新手)
数据结构·人工智能·经验分享·python·深度学习·算法·计算机视觉
北顾笙9803 小时前
day34-数据结构力扣
数据结构·算法·leetcode