hot 100 35. 搜索插入位置

搜索插入位置


问题描述

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

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


样例输入

cpp 复制代码
nums = [1,3,5,6], target = 5

样例输出

cpp 复制代码
2

评测用例规模与约定

1 <= nums.length <= 10^4

-10^4 <= numsi <= 10^4

nums 为 无重复元素 的 升序 排列数组

-10^4 <= target <= 10^4


解析

二分经典题目,注意边界范围处理就行。


参考程序

cpp 复制代码
class Solution {
public:
    int searchInsert(vector<int>& nums, int target) {
        int l=0,r=nums.size();
        int cnt=-1,ans=-1;
        for(int i=0;i<r-1;i++){
            if(nums[i]<target&&nums[i+1]>target)cnt=i+1;
        }if(target<=nums[0])cnt=0;if(target>nums[r-1])cnt=r;
        r-=1;
        while(l<=r){
            int mid=(l+r)>>1;
            if(nums[mid]>target)r=mid-1;
            if(nums[mid]<target)l=mid+1;
            if(nums[mid]==target){ans=mid;break;}
        }
        if(ans>=0)return ans;
        else return cnt;
    }
};

难度等级

⭐️⭐️(1~10星)

以个人刷题整理为目的,如若侵权,请联系删除~

相关推荐
手写码匠19 分钟前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力43 分钟前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试
lqqjuly1 小时前
MLA — 多头潜在注意力深度解析
深度学习·神经网络·算法
吴可可1231 小时前
SolidWorks草图转三维DWG技巧
算法
tyung1 小时前
Go 手写 Wait-Free SPSC 无界队列:无 CAS、无锁、泛型节点池
数据结构·后端·go
redaijufeng2 小时前
C++雾中风景7:闭包
c++·算法·风景
Chen_harmony2 小时前
一、数据结构概念和复杂度计算
数据结构
小欣加油2 小时前
leetcode287寻找重复数
数据结构·c++·算法·leetcode
尽兴-3 小时前
2.1 向量基础:Embedding、余弦相似度、欧氏距离、向量检索
算法·embedding·欧氏距离·向量检索·余弦相似度
Black蜡笔小新3 小时前
自动化AI算法训练服务器DLTM训推一体工作站赋能多行业智能化升级
人工智能·算法·自动化