【力扣每日一题04】数组篇--搜索插入位置

今天的题目,利用的是二分查找原理。很不幸我又没做出来,但是也很高兴发现自己的不足~

一、题目

给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。

示例 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

二、思路解析

由于官方答案我看不明白,因此找了另一种比较便于理解的做法。

二分查找相信各位都在 C 语言学过,只是忘得七七八八了。

这个解法首先要定义三个变量:left 、 right 、 mid .

并分别赋值为 left = 0; right = nums.length-1 ;

mid 的定义先卖个关子,放到后面再说。

这点搞定之后,接下来只要理解概念,剩下的就很简单了。

分三种情况,nums[mid] == target 、 nums[mid] <= target 和 nums[mid] >mid ;

第一种情况,证明我们找到了,直接返回 mid 就行了,因为此时 mid 正好是插入元素的下标

第二种情况,则说明 mid 给的值还太小了,我们让 left ++,稍后再做解释

第三种跟第二种大差不差,mid 过大,我们先让 right --。

完成之后,我们再把这个过程循环一遍,同时,在 循环中定义变量 mid = ( right + left ) /2 ;

即可大功告成。

三、完整代码

复制代码
class Solution {
    public int searchInsert(int[] nums, int target) {
        int left = 0;
        int right = nums.length-1;
        

        while(left<=right){

        int mid = (left+right)/2;

        if(nums[mid]==target) {
            return mid;
        }

        else if(nums[mid]<=target){
            left  = mid+1;
         }
            
        else {
             right = mid-1;
         }
        }


    return left;
    }
}

以上就是本篇博客的全部内容啦,如有不足之处,还请各位指出,期待能和各位一起进步!

相关推荐
放下华子我只抽RuiKe54 分钟前
机器学习全景指南-探索篇——发现数据内在结构的聚类算法
人工智能·深度学习·算法·机器学习·语言模型·数据挖掘·聚类
chools4 分钟前
一篇文章带你搞懂Java“设计模式”! - - 超长文(涵盖23种)万字总结!【汇总篇】
java·开发语言·设计模式
良逍Ai出海6 分钟前
OpenClaw 新手最该先搞懂的 2 套命令
android·java·数据库
6+h13 分钟前
【Spring】深度剖析IoC
java·后端·spring
Yupureki18 分钟前
《C++实战项目-高并发内存池》3.ThreadCache构造
服务器·c语言·c++·算法·哈希算法
程序员JerrySUN23 分钟前
别再把 HTTPS 和 OTA 看成两回事:一篇讲透 HTTPS 协议、安全通信机制与 Mender 升级加密链路的完整文章
android·java·开发语言·深度学习·流程图
j_xxx404_23 分钟前
C++算法:一维/二维前缀和算法模板题
开发语言·数据结构·c++·算法
x_xbx26 分钟前
LeetCode:111. 二叉树的最小深度
算法·leetcode·职场和发展
郝学胜-神的一滴33 分钟前
系统设计与面向对象设计:两大设计思想的深度剖析
java·前端·c++·ue5·软件工程
入目星河滚烫33 分钟前
网易互娱2020校招在线笔试—游戏研发第一批—游泳池-研发
算法·笔试·数据结构与算法