LeetCode 41. 缺失的第一个正数

缺失的第一个正数

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

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

方法一、哈希表法

哈希+标志位解决此问题。

实际上,对于一个长度为 N 的数组,其中没有出现的最小正整数只能在 [1,N+1] 中。

  1. 将数组中小于等于0的数转成N+1
  2. 将<=cnt的元素对应位置变为负数
  3. 返回第一个大于零的元素下标+1

Swift

swift 复制代码
func firstMissingPositive(_ nums: [Int]) -> Int {
        
        var nums = nums
        let cnt = nums.count
        
        //1.将数组中小于等于0的数转成N+1
        for (i, num) in nums.enumerated() {
            if  num <= 0 {
                nums[i] = cnt + 1
            }
        }
        
        //2.将<=cnt的元素对应位置变为负数
        for num in nums where num <= cnt {
            nums[num-1] = -abs(nums[num-1])
        }
        
        //3.返回第一个大于零的元素下标+1
        for i in 0..<cnt {
            if nums[i] > 0 {
                return i+1
            }
        }
        
        return cnt+1
    }

OC

c 复制代码
- (NSInteger)firstMissingPositive:(NSArray *)nums {
    
    NSMutableArray *numsM = [nums mutableCopy];
    NSInteger cnt = numsM.count;
    
    //1.将数组中小于等于0的数转成N+1
    for (NSInteger i=0; i<cnt; i++) {
        if ([numsM[i] integerValue] <= 0) {
            numsM[i] = [NSNumber numberWithInteger:cnt+1];
        }
    }
    
    //2.将<=cnt的元素对应位置变为负数
    for (NSInteger i=0; i<cnt; i++) {
        NSInteger num = [numsM[i] integerValue];
        
        if (num <= cnt) {
            numsM[num-1] = [NSNumber numberWithInteger:-labs([numsM[num-1] integerValue])];
        }
    }
    
    //3.返回第一个大于零的元素下标+1
    for (NSInteger i=0; i<cnt; i++) {
        if ([numsM[i] integerValue] > 0) {
            return i+1;
        }
    }
    
    return cnt+1;
}
相关推荐
Book思议-5 分钟前
【数据结构实战】栈的经典应用:后缀表达式求值 +中缀转后缀 ,原理 + 代码双通透
数据结构·算法··后缀表达式·后缀转中缀
炽烈小老头7 分钟前
【 每天学习一点算法 2026/03/30】跳跃游戏
学习·算法
m0_6265352017 分钟前
今日需要注意
数据结构
wuweijianlove24 分钟前
算法性能预测的统计模型与参数敏感性分析的技术6
算法
Just right26 分钟前
重学算法 数组 LC27移除元素
数据结构·算法
郝学胜-神的一滴26 分钟前
巧解括号序列分解问题:栈思想的轻量实现
开发语言·数据结构·c++·算法·面试
Jasmine_llq33 分钟前
《B4496 [GESP202603 一级] 数字替换》
数据结构·字符串遍历算法·字符替换算法·条件判断算法·字符串输入输出算法·顺序处理算法·批量字符修改算法
计算机安禾35 分钟前
【数据结构与算法】第15篇:队列(二):链式队列的实现与应用
c语言·开发语言·数据结构·c++·学习·算法·visual studio
算法鑫探44 分钟前
C语言密码验证:3次机会解锁
c语言·数据结构·算法·新人首发
穿条秋裤到处跑1 小时前
每日一道leetcode(2026.03.30):判断通过操作能否让字符串相等 II
算法·leetcode