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星)

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

相关推荐
田梓燊43 分钟前
力扣:23.合并 K 个升序链表
算法·leetcode·链表
re林檎1 小时前
算法札记——4.27
算法
AI人工智能+电脑小能手2 小时前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
数据牧羊人的成长笔记2 小时前
逻辑回归与Softmax回归
算法·回归·逻辑回归
郑州光合科技余经理2 小时前
同城O2O海外版二次开发实战:从支付网关到配送算法
开发语言·前端·后端·算法·架构·uni-app·php
Mrlxl.cn4 小时前
计算机网络——网络层
c语言·数据结构·计算机网络·考研
d111111111d5 小时前
STM32-UART封装问题解析
笔记·stm32·单片机·嵌入式硬件·学习·算法
寒秋花开曾相惜5 小时前
(学习笔记)4.2 逻辑设计和硬件控制语言HCL(4.2.1 逻辑门&4.2.2 组合电路和HCL布尔表达式)
linux·网络·数据结构·笔记·学习·fpga开发
Jiangxl~7 小时前
IP数据云如何为不同行业提供精准IP查询与风险防控解决方案?
网络·网络协议·tcp/ip·算法·ai·ip·安全架构
李伟_Li慢慢7 小时前
wolfram详解山峦算法
前端·算法