leetcode41 缺失的第一个正数

一、问题描述

二、解题思路

由于本题要求时间复杂度为O(n),空间复杂度为常数级,所以不能使用枚举和哈希表来解决,智能就地解决,可以用向量nums来模拟哈希表(原地哈希),解题思路如下:

(1)首先,遍历向量nums,如果numsi>0且未在正确的位置上,就将其换到正确的位置上,注意不能越界,完成遍历,将所有正整数n放置到索引位置n-1;

(2)然后,遍历操作完后的nums向量,如果在遍历过程中发现numsi!=i+1,就返回i+1,这个数字即为缺失的数字;

若遍历完成仍未发现,就返回n+1,即为缺失的最小正数。

注意:交换到正确位置要用while,因为要保证换过来的数字也要换到正确的位置。

三、代码实现

cpp 复制代码
class Solution {
public:
    int firstMissingPositive(vector<int>& nums) {
        //将数字i放到i-1的位置上(i>0),然后再进行遍历寻找缺失的数字
        int n=nums.size();
        //将数字i放到i-1位置
        for(int i=0;i!=nums.size();i++){
            //注意:使用while,保证交换过来的数也能被放到正确的位置
            while((nums[i]!=i+1)&&(nums[i]>0)&&(nums[i]<=n))
                swap(nums[i],nums[nums[i]-1]);
        }
        //遍历寻找缺失的数字
        for(int i=0;i!=nums.size();i++)
            if(nums[i]!=i+1) return i+1;
        return n+1;
    }
};
相关推荐
I Promise341 小时前
智驾APA_HPA可行驶区域检测算法工程师面试问题整理可参考
算法·面试·职场和发展
智者知已应修善业1 小时前
【51单片机按键控制1分钟正计时倒计时暂停复位】2024-1-2
c++·经验分享·笔记·算法·51单片机
QT-Neal2 小时前
C++ 编译过程详解
c++
weixin_468466852 小时前
UNet 模型结构从零搭建与实战解析
人工智能·深度学习·算法·机器学习·ai·unet
Littlehero_1212 小时前
QT自定义控件之热换站远程监控系统
c++·qt
努力努力再努力wz2 小时前
【Qt入门系列】一文掌握 Qt 常用显示类控件:QLCDNumber、QProgressBar 与 QCalendarWidget
c语言·开发语言·数据结构·数据库·c++·git·qt
Useasy_JIJIANYUN2 小时前
合作快讯:极简云呼叫中心(Useasy)正式上架Zoho全球应用市场!
算法
isyoungboy2 小时前
Delaunay 拓扑图割法一种特征抽稀算法
算法
Shan12052 小时前
算法案例精讲:连接所有点的最小费用
算法