算法---缺失的第一个正数

题目

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

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


示例 1:

输入:nums = [1,2,0]
输出:3
示例 2:

输入:nums = [3,4,-1,1]
输出:2
示例 3:

输入:nums = [7,8,9,11,12]
输出:1


提示:

1 <= nums.length <= 5 * 105
-231 <= nums[i] <= 231 - 1

解决思路

借用map 就可以实现,但是如果不借用map,在原空间上,也可以实现,不过想要使用原来的数据,会有侵略性,会把原来的数据修改掉。

解决方法

方法一:

kotlin 复制代码
    fun firstMissingPositive(nums: IntArray): Int {
        val size = nums.size
        nums.forEachIndexed { index, i ->
            if (i <= 0) {
               nums[index] = size + 1
            }
        }
        nums.forEachIndexed { index, i ->
            if (i.absoluteValue in 1..size && nums[i.absoluteValue -1]  > 0) {
                nums[i.absoluteValue -1] = -nums[i.absoluteValue -1]
            }
        }

        nums.forEachIndexed { index, i ->
            if (i >= 0){
                return index + 1
            }
        }

        return size + 1
    }

方法二:

kotlin 复制代码
    fun firstMissingPositive2(nums: IntArray): Int {
        val size = nums.size
        var temp = 0

        nums.forEachIndexed { index, _ ->

            while (nums[index] in 1 until size && nums[nums[index] - 1] != nums[index]) {

                temp = nums[nums[index] - 1]
                nums[nums[index] - 1] = nums[index]
                nums[index] = temp
            }
        }
        nums.forEachIndexed { index, i ->
            if (index != i - 1) {
                return index + 1
            }
        }

        return size + 1

    }

总结

算法是很看一个人的思维逻辑的,所以很多都会考验一下算法。

算法确实重要。

做了快一年算法了,确实 学习如园中小草,不见其增,日有所长

面试遇到算法就很轻松就过了

相关推荐
fie888937 分钟前
MATLAB有限元框架程序
python·算法·matlab
小郭团队40 分钟前
1_5_五段式SVPWM (传统算法反正切+DPWM1)算法理论与 MATLAB 实现详解
人工智能·嵌入式硬件·算法·dsp开发
思成Codes1 小时前
ACM训练:接雨水3.0——动态接雨水
数据结构·算法
alphaTao1 小时前
LeetCode 每日一题 2026/1/12-2026/1/18
python·算法·leetcode
sin_hielo1 小时前
leetcode 2943
数据结构·算法·leetcode
Snow_day.2 小时前
有关平衡树
数据结构·算法·贪心算法·动态规划·图论
Hcoco_me2 小时前
大模型面试题75:讲解一下GRPO的数据回放
人工智能·深度学习·算法·机器学习·vllm
Xの哲學2 小时前
Linux设备驱动模型深度解剖: 从设计哲学到实战演练
linux·服务器·网络·算法·边缘计算
明洞日记2 小时前
【CUDA手册002】CUDA 基础执行模型:写出第一个正确的 Kernel
c++·图像处理·算法·ai·图形渲染·gpu·cuda
企业对冲系统官3 小时前
基差风险管理系统集成说明与接口规范
大数据·运维·python·算法·区块链·github