当前位置: 首页 > news >正文

leetcode 41.缺失的第一个正数

思路:首先就是O(n)时间复杂度,O(n)空间复杂度的,其实很简单,我们只需要定义一个哈希表,遍历一遍数组的时候计数数组中的元素就行;之后再次遍历一遍,只不过这回是从1开始比照哈希表里存不存在这个正整数,从而获得答案。

class Solution {
    public int firstMissingPositive(int[] nums) {
        Map<Integer,Integer>map=new HashMap<Integer,Integer>();
        for(int i=0;i<nums.length;i++){
            map.put(nums[i],map.getOrDefault(nums[i],0)+1);
        }
        int res=0;
        for(int i=1;;i++){
            if(!map.containsKey(i)){
                res=i;
                break;                
            }
        }
        return res;
    }
}

但是,这不是题目本身的初衷。那么我们怎么想到用O(1)的空间复杂度来实现呢?这里我们需要明确一点,那就是我们需要找的正整数一定会在[1,N+1]的范围之内。为什么呢?

我们可以这样想:如果[1,N]的数全在这个数组当中,那么最小的正整数就应该是N+1;

那么如果这个数组中的数全都不是在[1,N]内的数,那么我们就会看到最小正整数就应该是1.那么这个区间就自然而然地推理出来在这个范围之内了。

并没有严格的证明,只是考虑了两种极端的情况,来判断最小正整数的最大值和最小值。

既然答案就在这个区间内,我们怎么判断它是哪一个呢?题解中给出的方法就是如果遍历到数x,那么我们就在坐标x-1的位置标记。如此标记全部完毕之后,如果全部标记完了,那么就说[1,N]的数全在这个数组中;

那么如果没有标记完呢?标记要怎么标记呢?标记就可以让正数变成负数。如果一个数本身就是负数,我们就把这个负数变成>=N+1的数,这样就不影响我们标记数组位置了。这个时候,当我们标记完之后出现正数的坐标+1就是答案了。

class Solution {
    public int firstMissingPositive(int[] nums) {
        for(int i=0;i<nums.length;i++){
            if(nums[i]<=0){
                nums[i]=nums.length+2;
            }
        }
        for(int i=0;i<nums.length;i++){
            if(Math.abs(nums[i])>0&&Math.abs(nums[i])<=nums.length){
                if(nums[Math.abs(nums[i])-1]>0)
                nums[Math.abs(nums[i])-1]=-nums[Math.abs(nums[i])-1];
                else
                continue;
            }
        }
        boolean flag=false;
        int res=0;
        for(int i=0;i<nums.length;i++){
            if(nums[i]>0){
                flag=true;
                res=i+1;
                break;
            }
        }
        return flag==true?res:nums.length+1;
    }
}

相关文章:

  • 58.以太网数据回环实验(1)理论知识
  • C++指南-标准库,数学库,数据结构
  • 参数校验学习笔记
  • 快充协议方案 TYPE-C口取电支持PD5V、 9V、 12V、 15V、 20V
  • Unity3D DOTS中ECS核心架构详解
  • Windows上安装 nodejs,npm 和 yarn详细教程
  • 玩转云服务:Oracle Cloud甲骨文永久免费云主机配置指南(续)
  • python基础(13魔法方法介绍)
  • 江协科技STM32学习- P7 GPIO输入
  • 打造 LLMOps 时代 Prompt 数据驱动引擎
  • Java、python、php版 美发美甲预约服务平台 美容院管理系统(源码、调试、LW、开题、PPT)
  • Python相关系数导图
  • ChatGPT 3.5/4新手使用手册(附:案例)
  • 如何禁止电脑访问网站
  • 看论文文献用哪种阅读器比较好?
  • “决胜面试:高频题目与算法策略一览”
  • 机器学习 之 决策树与随机森林的实现
  • 知乎知+和信息流广告报价,知乎推广多少钱?
  • keil中内存的存储规律
  • 最新国内Docker 安装
  • 证监会副主席王建军被查
  • 国家医保局副局长颜清辉调任人社部副部长
  • 运动健康|不同能力跑者,跑步前后营养补给差别这么大?
  • 出行注意防晒补水,上海五一假期以多云天气为主最高33℃
  • 马上评丨又见酒店坐地起价,“老毛病”不能惯着
  • “上海-日喀则”直飞航线正式通航,将于5月1日开启首航