给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
请必须使用时间复杂度为
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] <= 104nums为 无重复元素 的 升序排列数组-104 <= target <= 104
cppclass Solution { public: int searchInsert(vector<int>& nums, int target) { int l=0,r=nums.size()-1; while(l<r) { int mid=(l+r)/2; if(nums[mid]<target) { l=mid+1; }else{ r=mid; } } if(nums[r]<target) return nums.size(); return l; } };
LeetCode 35. 搜索插入位置
Liangwei Lin2026-05-12 11:38
相关推荐
地平线开发者32 分钟前
profiler debug 工具用法与高一致性策略编程大师哥37 分钟前
匿名函数 lambda + 高阶函数我叫袁小陌1 小时前
算法解题思路指南地平线开发者1 小时前
Conv+BN+Add+ReLU 融合机制简介也曾看到过繁星1 小时前
数据结构---顺序表yuanyuan2o21 小时前
模型预训练:Hugging Face Transformers 基础杨充1 小时前
1.3 浮点型数据设计灵魂妄想出头的工业炼药师2 小时前
GS slam monomeilindehuzi_a2 小时前
深入浅出数据结构:Python 字典(Dict)与集合(Set)的哈希表底层全链路追踪