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

Javascript每天一道算法题(十七)——缺失的第一个正整数_困难

文章目录

  • 前言
  • 1、问题
  • 2、示例
  • 3、解决方法
    • (1)方法1
  • 总结


前言

提示:


1、问题

给你一个未排序的整数数组 nums ,请你找出其中没有出现的最小的正整数。
请你实现时间复杂度为 O(n) 并且只使用常数级别额外空间的解决方案。

看了很久示例才看明白说了啥。
首先正整数说大于0的数字,如1、2、3、4、5…
如示例1 [0,1,2]. 返回3 因为1,2数组中有了,所以最小的为3
示例2[-1,1,3,4] 返回2。因为1和3 之间没有2,2就是那个丢失的第一个正整数
示例3 [7,8,9,11,12] 因为没有正整数1,所以1就是那个丢失的第一个正整数

2、示例

示例 1:
输入:nums = [1,2,0]
输出:3
示例 2:
输入:nums = [3,4,-1,1]
输出:2
示例 3:
输入:nums = [7,8,9,11,12]
输出:1

3、解决方法

(1)方法1

let nums = [3,4,-1,1]
var firstMissingPositive = function(nums) {let min = 1; // 1:定义一个可能返回的最小正整数nums.sort((a,b) => a-b) // 2: 排序let newArray = [] // 3: 定义一个接收正整数的数组// 4:第一次遍历:nums.forEach((item, index) => {// 4: 将数组中大于等于1 并且 小于数组长度的值 存入新数组// 如示例二新数组为[1, empty, 3]if(item >= 1 && nums[index] < nums.length){newArray[nums[index] - 1] = nums[index]}});console.log('zzz', nums, newArray);// 5:第二次遍历:检查下标是否喝值相对应(下标+1 === 当前下标的值)for(let i=0;i<newArray.length;i++){// 5-1:如果不等于说明当前下标+1就是缺少正整数的值if(newArray[i] != i + 1){min = i + 1break;} else {// 5-2:如果都符合条件,就如示例一中[1,2]都符合条件,所以最小的值就是当前下标+1 + 1// 下标是从0开始的,当前值下标为 i+ 1(包括最后一个值),比最后一个值下标还大的就是i+2了// 如示例[1,2]中2的下标为1,要等于这个值就是下标+1,要大于这个值就是下标+2// 为什么不直接使用当前item的值呢?由于是用下标插入的,所以item的值可以为 emptymin = i + 2}}console.log('mew', min); // 6:返回缺失的最小正整数
};
firstMissingPositive(nums)

总结

(1)难度: 困难
(2)思路:遍历一次数组把大于等于1的和小于数组长度大小的值放到新数组(newArray)对应位置,然后再遍历一次数组查当前下标是否和值对应,如果不对应那这个下标+1就是答案,否则遍历完都没出现那么答案就是当前下标加2。
(3)注意点:为什么要下标+1和+2在第五步有详细说明

http://www.lryc.cn/news/242701.html

相关文章:

  • 【React】路径别名配置
  • 前缀和——238. 除自身以外数组的乘积
  • MySql数据库常用指令(二)
  • zookeeper 单机伪集群搭建简单记录
  • 【Linux】匿名管道与命名管道,进程池的简易实现
  • HTML5+ API 爬坑记录
  • idea git将某个分支内的commit合并到其他分支
  • Google hacking语法
  • Redis集群(新)
  • [JVM] 常用调优参数
  • 【nlp】3.5 Transformer论文复现:3.解码器部分(解码器层)和4.输出部分(线性层、softmax层)
  • 宝塔 Linux 面板安装一个高大上的论坛程序 —— Flarum
  • 数字化转型如何赋能企业实现数字化增值?
  • 深度学习之九(Transformers)
  • pgz easyexcel如何给excel文件添加自定义属性
  • 【unity实战】实现一个放置3d物品建造装修系统(附项目源码)
  • 计算机网络之应用层
  • Let’s xrOS 一款让你优先体验社区创作者的 visionOS App工具
  • 武汉教育E卡通学生证照片尺寸要求及证件照集中采集方法
  • C++《i+1》系列文章汇总
  • GEE:通过将 Landsat 5、7、8、9 的 C02 数据集合并起来,构建 NDVI 长时间序列
  • Visual Studio 中文注释乱码解决方案
  • 如何将本地websocket发布至公网并实现远程访问?
  • android ffmpeg
  • 初学剪辑者找视频素材就上这6个网站
  • C/C++---------------LeetCode第2824. 统计和小于目标的下标对数目
  • 【深度学习】因果推断与机器学习
  • HTTPS攻击怎么防御?
  • kubernetes|云原生|Deployment does not have minimum availability 的解决方案(资源隐藏的由来)
  • 2023.11.22 IDEA Spring Boot 项目热部署