Leetcode35 —— 搜索插入位置(二分查找)

题目:

题解:

最直接的做法是线性遍历,如下代码,但这样的时间复杂度为(n),达不到题目要求。

复制代码
class Solution {
public:
    int searchInsert(vector<int>& nums, int target) {
        for(int i = 0; i<nums.size();i++){
            if(nums[i] >= target){return i;}
            
        }
        return nums.size();
    }
};

结合二分查找法:

复制代码
class Solution {
public:
    int searchInsert(vector<int>& nums, int target) {
        int n = nums.size();
        int ans = n, left = 0,right = n-1; //ans是最终求解的位置
        while(left <= right){
            int mid = (left + right)/2;
            if(target <= nums[mid]){
                ans = mid;
                right = mid-1;
            }else{
                left = mid+1;
            }
        }    
        return ans;
        }
};
相关推荐
人间寥寥情难诉15 分钟前
LRU算法本地实现
java·算法·spring
moonsea020318 分钟前
2026.4.2
开发语言·c++·算法
cpp_250124 分钟前
P10376 [GESP202403 六级] 游戏
c++·算法·动态规划·题解·洛谷·gesp六级
智者知已应修善业26 分钟前
【51单片机4个IO实现16按键可扩展独立按键64矩阵驱动显示矩阵原值】2023-5-8
c++·经验分享·笔记·算法·51单片机
hui-梦苑26 分钟前
[GROMACS]模拟数据分析前轨迹文件生成-轨迹预处理
人工智能·算法·数据分析
蒸汽求职29 分钟前
低延迟系统优化:针对金融 IT 与高频交易,如何从 CPU 缓存行(Cache Line)对齐展现硬核工程底蕴?
sql·算法·缓存·面试·职场和发展·金融·架构
田梓燊32 分钟前
leetcode 239
数据结构·算法·leetcode
CoderCodingNo9 小时前
【NOIP】2011真题解析 luogu-P1003 铺地毯 | GESP三、四级以上可练习
算法
iFlyCai9 小时前
C语言中的指针
c语言·数据结构·算法
查古穆9 小时前
栈-有效的括号
java·数据结构·算法