hot 100 35. 搜索插入位置

搜索插入位置


问题描述

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

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


样例输入

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

样例输出

cpp 复制代码
2

评测用例规模与约定

1 <= nums.length <= 10^4

-10^4 <= nums[i] <= 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星)

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

相关推荐
汀、人工智能1 天前
[特殊字符] 第21课:最长有效括号
数据结构·算法·数据库架构·图论·bfs·最长有效括号
Boop_wu1 天前
[Java 算法] 字符串
linux·运维·服务器·数据结构·算法·leetcode
故事和你911 天前
洛谷-算法1-2-排序2
开发语言·数据结构·c++·算法·动态规划·图论
Fcy6481 天前
算法基础详解(三)前缀和与差分算法
算法·前缀和·差分
kvo7f2JTy1 天前
基于机器学习算法的web入侵检测系统设计与实现
前端·算法·机器学习
List<String> error_P1 天前
蓝桥杯最后几天冲刺:暴力大法(一)
算法·职场和发展·蓝桥杯
迈巴赫车主1 天前
蓝桥杯3500阶乘求和java
java·开发语言·数据结构·职场和发展·蓝桥杯
流云鹤1 天前
Codeforces Round 1090 (Div. 4)
c++·算法
wljy11 天前
第十三届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组(个人见解,已完结)
c语言·c++·算法·蓝桥杯·stl
高一要励志成为佬1 天前
【数据结构】算法复杂度
数据结构