力扣每日一题35:搜索插入的位置

题目描述:

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

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

示例 1:

复制代码
输入: nums = [1,3,5,6], target = 5
输出: 2

示例 2:

复制代码
输入: nums = [1,3,5,6], target = 2
输出: 1

示例 3:

复制代码
输入: nums = [1,3,5,6], target = 7
输出: 4

提示:

  • 1 <= nums.length <= 104
  • -104 <= nums[i] <= 104
  • nums无重复元素升序排列数组
  • -104 <= target <= 104

思路及题解:

找到第一个大于等于target的数的下标即可,如果没有大于等于target的数,就插入数组尾部,即返回numsSize。用二分法查找。

代码:

复制代码
int searchInsert(int* nums, int numsSize, int target){
    int lo=0;
    int hi=numsSize-1;
    int mid;
    int ans=numsSize;
    // if(nums[0]>target) return 0;
    // if(target>nums[hi]) return numsSize;
    //找第一个大于等于target的数
    while(lo<=hi)
    {
        mid=(lo+hi)/2;
        if(target<=nums[mid])
        {
            ans=mid;
            hi=mid-1;
        }
        else
        {
            lo=mid+1;
        }
    }
    return ans;
}
相关推荐
天若有情6738 分钟前
循环条件隐藏陷阱:我发现了「同循环双条件竞态问题」
c++·学习·算法·编程范式·while循环··竞态
j_xxx404_15 分钟前
C++算法:前缀和与哈希表实战
数据结构·算法·leetcode
我能坚持多久15 分钟前
【初阶数据结构07】——栈与队列的代码实现与解析
数据结构
We་ct39 分钟前
LeetCode 22. 括号生成:DFS回溯解法详解
前端·数据结构·算法·leetcode·typescript·深度优先·回溯
mit6.8241 小时前
tabbi风波|开源协议
算法
是梦终空1161 小时前
C++中的职责链模式变体
开发语言·c++·算法
仰泳的熊猫1 小时前
题目2270:蓝桥杯2016年第七届真题-四平方和
c++·算法·蓝桥杯
CoovallyAIHub1 小时前
CVPR 2026 | VisualAD:去掉文本编码器,纯视觉也能做零样本异常检测
算法·架构·github
CoovallyAIHub1 小时前
东南大学提出 AutoIAD:多 Agent 驱动的工业异常检测自动化框架
算法·架构·github
ccLianLian1 小时前
算法·字符串
算法·哈希算法