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;
        }
};
相关推荐
淞綰1 分钟前
c语言的练习-字符串的练习-寻找最长连续字符以及出现次数
c语言·数据结构·学习·算法·c语言的练习
计算机安禾3 分钟前
【c++面向对象编程】第27篇:空类的大小为什么是1?——C++对象标识的秘密
开发语言·c++·算法
信竞星球_少儿编程题库25 分钟前
2026年全国信息素养大赛算法应用主题赛 丝路新城 Python 模拟卷(三)
开发语言·python·算法
云泽80832 分钟前
笔试算法 - 滑动窗口篇(二):从异位词到最小覆盖子串的通用框架
c++·算法
qq_2965532737 分钟前
[特殊字符] 搜索插入位置:从O(n)到O(log n)的优雅进化
数据结构·算法·面试·分类·柔性数组
凯瑟琳.奥古斯特41 分钟前
力扣3654:二维矩阵连续空位统计
数据结构·数据库·算法·职场和发展
basketball6161 小时前
并查集基础算法总结 C++ 实现
开发语言·c++·算法
故事和你911 小时前
洛谷-【图论2-2】最短路3
开发语言·数据结构·c++·算法·动态规划·图论
yong99901 小时前
基于VC++的图像匹配金字塔算法
c++·算法·计算机视觉