【LC】41. 缺失的第一个正数

题目描述:

给你一个未排序的整数数组 nums ,请你找出其中没有出现的最小的正整数。

请你实现时间复杂度为 O(n) 并且只使用常数级别额外空间的解决方案。

示例 1:

复制代码
输入:nums = [1,2,0]
输出:3
解释:范围 [1,2] 中的数字都在数组中。

示例 2:

复制代码
输入:nums = [3,4,-1,1]
输出:2
解释:1 在数组中,但 2 没有。

示例 3:

复制代码
输入:nums = [7,8,9,11,12]
输出:1
解释:最小的正数 1 没有出现。

题解:

复制代码
class Solution {
    public int firstMissingPositive(int[] nums) {
        int n = nums.length;
        for (int i = 0; i < n; ++i) {
            while (nums[i] > 0 && nums[i] <= n && nums[nums[i] - 1] != nums[i]) {
                int temp = nums[nums[i] - 1];
                nums[nums[i] - 1] = nums[i];
                nums[i] = temp;
            }
        }
        for (int i = 0; i < n; ++i) {
            if (nums[i] != i + 1) {
                return i + 1;
            }
        }
        return n + 1;
    }
}
相关推荐
红烧柯基2 小时前
解决redis序列号和反序列化问题
java·数据库·redis
Tanecious.2 小时前
初阶数据结构--排序算法(全解析!!!)
数据结构·算法·排序算法
KAI_KD3 小时前
自定义JackSon配置
java
运维@小兵3 小时前
SpringBoot获取用户信息常见问题(密码屏蔽、驼峰命名和下划线命名的自动转换)
java·spring boot·后端
新时代苦力工3 小时前
Java实现使用EasyExcel按模板导出文件
java
小陈093 小时前
Java后端图形验证码的使用
java·开发语言·状态模式
27669582923 小时前
得物 小程序 6宫格 分析
java·python·小程序·得物·得物小程序·得物六宫格·六宫格验证码
知了一笑3 小时前
通过IP计算分析归属地
java·ip·ip定位·ip计算
沃野_juededa4 小时前
uniapp自定义选项卡
java·前端·javascript
hu_yuchen4 小时前
C++:Lambda表达式
开发语言·c++·算法