搜索插入位置(二分查找)

目录

二分查找逻辑

Code


LeetCode第35题

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

请必须使用时间复杂度为 O(log n) 的算法。

二分查找逻辑

每次循环都将搜索范围减半:

  • left 和 right 初始覆盖整个数组
  • 每次循环后,left 或 right 更新,将搜索范围减半
  • 最坏情况下需要 log₂n 次循环

Code

javascript 复制代码
var searchInsert = function (nums, target) {
    let left = 0;
    let right = nums.length - 1;

    while (left <= right) {
        const mid = left + Math.floor((right - left) / 2);
        if (nums[mid] === target) {
            return mid;  // 找到目标,直接返回索引
        } else if (nums[mid] < target) { // 目标在右侧 
            left = mid + 1;
        } else { // 目标在右侧
            right = mid - 1;
        }
    }

    // 循环结束后,left 就是插入位置
    return left;
};
相关推荐
noipp44 分钟前
推荐题目:洛谷 P1737 [NOI2016] 旷野大计算
linux·数据结构·算法
QiLinkOS1 小时前
极客精神与商业思维的融合实践(2)
c语言·c++·人工智能·算法·开源协议
lzjava20241 小时前
Python的数据结构,推导式、迭代器和生成器
数据结构·windows·python
code_pgf2 小时前
改进模型架构来减少MLLMs中的幻觉现象
人工智能·深度学习·算法
2301_764441332 小时前
基于AI的本地文件归档智能管理工具梳理
人工智能·python·算法·目标检测·交互
无限码力2 小时前
美团研发岗 4月18号笔试真题 - 包包的最长公共子序列3
算法·美团笔试题·美团研发岗笔试题·美团机试题
阿里matlab建模师2 小时前
基于matlab时域频域处理的语音信号变声处理系统设计与算法原理(论文+程序源码+GUI图形用户界面)——变声算法
算法·matlab·语音识别
IMPYLH2 小时前
HTML 的 <abbr> 元素
前端·算法·html
leo__5202 小时前
小波特征与模糊支持向量机(FSVM)的脑电信号分类方法
算法·支持向量机·分类
wabs6662 小时前
关于动态规划【纯粹的0-1背包需要思考的问题】
算法·动态规划