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

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

相关推荐
葳_人生_蕤2 小时前
力扣Hot100——234.回文链表
算法·leetcode·链表
自信150413057592 小时前
数据结构之实现链式结构二叉树
c语言·数据结构·算法
EE工程师2 小时前
数据结构篇 - C语言如何实现OOP
数据结构·oop
Barkamin2 小时前
堆排序简单实现
java·数据结构·算法·排序算法
迈巴赫车主2 小时前
天梯赛 L2-004 这是二叉搜索树吗?java
java·开发语言·数据结构·算法·天梯赛
沐苏瑶2 小时前
Java 数据结构精讲:二叉树遍历算法与底层实现剖析
数据结构·算法
董董灿是个攻城狮3 小时前
大模型连载8:词向量如何表示近义词?
人工智能·python·算法·机器学习
Jasmine_llq3 小时前
《B4001 [GESP202406 一级] 立方数》
算法·单输入处理·整数算术运算·立方数枚举验证算法(核心逻辑)·循环终止优化算法·状态标记算法·三元运算符输出
芸忻3 小时前
day 13 第六章 二叉树 part01代码随想录算法训练营71期
数据结构·算法