【LeetCode笔记】448. 找到所有不存在的数(Java、原地)

文章目录

  • 题目描述
  • 思路 & 代码

题目描述

  • 说实话,第一眼看题让我想到那道“往1 ~ 1024中加入一个数,用中学生也会的方法找到这个数"(答案是 (1024! + x) - 1024! )
  • 如果没有时空复杂度限制的话,用哈希表可以直接做
    在这里插入图片描述

思路 & 代码

  • 首先找到题目关键词:1 <= a[i] <= n,n为a[ ]的长度。至于“一些出现两次、一些出现一次”这个倒是不太重要(或者说有Dalao也利用了这个条件)
  • 那么,我们只需要达到这样一个效果即可:遍历a[i],对于出现过的a[i]值,把对应的下标存储的值变成一个**”不在[1, n]内,并且可以变回原值的值“**即可。
  • 有两个方法:取负、加n。加n会快一点
class Solution {public List<Integer> findDisappearedNumbers(int[] nums) {List<Integer> ans = new ArrayList<>();int len = nums.length;// 使用第 n - 1位来判断是否出现过for(int i = 0; i < len; i++){// 让对应的存储位置的值 + n// 负数也行,不过会慢一点,总归就是变成一个不在【1,n】内,同时可以取得原来值的值nums[(nums[i] - 1) % len] += len;}for(int i = 0; i < len; i++){if(nums[i] <= len){ans.add(i + 1);}}return ans;}
}
  • 无注释版
class Solution {public List<Integer> findDisappearedNumbers(int[] nums) {List<Integer> ans = new ArrayList<>();for(int num : nums) {nums[(num - 1) % nums.length] += nums.length;}for(int i = 0; i < nums.length; i++) {if(nums[i] <= nums.length) {ans.add(i + 1);}}return ans;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/504529.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【LeetCode笔记】146. LRU缓存机制(Java、双向链表、哈希表)

文章目录题目描述思路 & 代码LinkedHashMap 的写法题目描述 大名鼎鼎的超高频面试题太感动&#xff0c;在这道题上花了太多时间了&#xff0c;今天终于补上博客了TvT 思路 & 代码 结构用的是&#xff1a;双向链表 哈希表。可以满足O(1)时间复杂度put()&#xff1a…

simulink和c语言开发,Simulink之嵌入式C代码生成-应用层和底层的接口

今天给大家带来的仍然是基于MBD的嵌入式代码生成&#xff0c;主要把应用层和底层接口之间的代码生成配置说一下。本周末会更新功能安全相关&#xff0c;欢迎大家留言交流&#xff01;作为一个总是用C写代码的人来说&#xff0c;第一次接触到基于MBD的代码生成的时候就迫不及待的…

【LeetCode笔记】215. 数组中的第K个最大元素(Java、快排、堆排、并发快排)

文章目录题目描述思路 & 代码快排基于 Fork / Join 的并发快排针对 topK 的快排优化堆排基本堆排结合题目的堆排二刷题目描述 大名鼎鼎的TOP K&#xff0c;主要考察排序快排 & 堆排 思路 & 代码 快排 没啥好说的&#xff0c;就是快排结束后&#xff0c;返回倒…

c语言中怎么画直线,ps如何画直线 【操作流程】

大家都知道电脑使用起来非常方便&#xff0c;但遇见ps如何画直线的时候就非常头疼了&#xff0c;如果你是第一次遇到ps如何画直线&#xff0c;怎么样才能快速解决ps如何画直线带来的烦恼呢&#xff1f;小编为大家收集了很多关于ps如何画直线问题的解决方法&#xff0c;下面请看…

【LeetCode笔记】470. 用Rand7()实现Rand10()(Java、概率)

文章目录题目描述代码 & 思路更新版三刷 - 极简版题目描述 貌似是比较高频的面试题目啊&#xff0c;有学概率论内味了&#xff08;讲道理我概率论学得不好&#xff09; 代码 & 思路 先用Rand7实现RandN&#xff08;N > 10&#xff09;&#xff0c;类似进制&…

【纠错记录】本地FTP服务器无法被外部连接

问题描述 在本地主机开了个FTP服务器&#xff0c;本机可以正常访问&#xff0c;但是外部主机不能访问FTP服务器 解决方法 ① 一开始以为是服务端Xlight FTP的问题&#xff0c;检查权限并没有发现问题 ② 接着考虑到有没有可能是客户端Flash FXP的问题&#xff0c;于是尝试直…

双线性插值算法c 语言实现,双线性插值 - CristianoC的个人空间 - OSCHINA - 中文开源技术交流社区...

前言最近在学习LBP&#xff0c;其中的圆形LBP特征由于计算的值可能不是整数&#xff0c;即计算出来的点不在图像上&#xff0c;我们要使用计算出来的点的插值点。目的的插值方法有很多&#xff0c;Opencv使用的是双线性插值&#xff0c;今天就来介绍一下双线性插值。概述先给大…

【LeetCode笔记】543. 二叉树的直径(Java、dfs、二叉树)

文章目录题目描述思路 & 代码题目描述 思路 & 代码 由这个结论考虑&#xff1a;直径中一定有一个父结点&#xff0c;那么当前直径长度就是&#xff1a; 当前父结点的左子树深度 右子树深度那么&#xff0c;只要遍历所有结点的最长直径值即可流程&#xff1a;在找每一…

【LeetCode笔记】461. 汉明距离(Java、位运算)

文章目录题目描述思路 & 代码更新版题目描述 既然是二进制&#xff0c;那就十有八九用位运算符既然是不同&#xff0c;那肯定用异或 思路 & 代码 两种方法&#xff0c;总体来说都是处理异或值方法一&#xff0c;转换成字符串&#xff0c;再遍历&#xff08;会慢一点…

android 自定义桌面图标大小设置,手机桌面图标尺寸可以改?OriginOS重新定义个性化...

原标题&#xff1a;手机桌面图标尺寸可以改&#xff1f;OriginOS重新定义个性化随着安卓定制化系统同质化情况的加重&#xff0c;越来越多的终端厂商开始探索一场新的变革。深耕手机领域的vivo&#xff0c;自然也察觉到了这一点。经过不断地努力和尝试之后&#xff0c;vivo终于…

【LeetCode笔记】347. 前K个高频元素(Java、优先队列、小顶堆、HashMap)

文章目录题目描述思路 & 代码更新版&#xff1a;引入 stream 流 Lambda题目描述 时间复杂度小于O(n*logn)&#xff0c;否则直接sort&#xff0c;再遍历就很轻松。很有学习价值的题目&#xff0c;第一次使用了优先队列PriorityQueue。 思路 & 代码 首先遍历数组&am…

【LeetCode笔记】240. 搜索二维矩阵II 剑指 Offer 04 二维数组中的查找(Java、指针)

文章目录题目描述思路 & 代码更新版题目描述 两道题一样的有序 搜索&#xff0c;明摆着二分查找但是比较懒…选取了题解里的指针做法 思路 & 代码 时间复杂度O(m n)&#xff0c;原理 & 思路 & 证明可见代码注释。代码很简单&#xff0c;主要是弄明白正确…

【LeetCode笔记】238. 除自身以外数组的乘积(Java、思路题)

文章目录题目描述思路 & 代码更新版题目描述 首先暴力二层循环肯定可以&#xff0c;然后先累乘整个数组&#xff0c;再用除法肯定也行。但是很遗憾&#xff0c;两种做法都不满足题目说明。 思路 & 代码 O(n) & O(1)考虑到这个核心&#xff1a;ans[i] 就是当前元…

【LeetCode笔记】236. 二叉树的最近公共祖先(Java、二叉树、DFS)

文章目录题目描述思路 & 代码题目描述 ac了&#xff0c;但是看了题解发现有更好的做法 思路 & 代码 对于一个结点rootNode&#xff0c;p、q有这么几种情况&#xff1a; p、q分别在其左右子树中&#xff0c;那么好说&#xff0c;rootNode就是答案p、q都在其右子树中…

linux关机命令_Linux基于centOS 7.6常见的Linux命令

一、linux关机命令&#xff1a;1.shutdown命令安全地将系统关机&#xff08;推荐&#xff09;参数说明:[-r] 重启计算器。[-h] 关机后关闭电源〔halt〕。[-c] cancel current process取消目前正在执行的关机程序。[-time] 设定关机〔shutdown〕前的时间。shutdown -h now 立刻…

【LeetCode笔记】221. 最大正方形(Java、动态规划、思路题)

文章目录题目描述思路 & 代码更新版题目描述 显而易见地可以用dp来写&#xff0c;问题在于如何考虑状态转移方程 思路 & 代码 首先再加一层外墙&#xff0c;就不用边界判断了maxSqure[i]&#xff1a;以当前格子为右下角的正方形&#xff0c;可达到的最大边长这是由…

linux内存管理_浅谈Linux内存管理

1. 扫盲篇1.1 操作系统存储层次常见的计算机存储层次如下&#xff1a;寄存器&#xff1a;CPU提供的&#xff0c;读写ns级别&#xff0c;容量字节级别。CPU缓存&#xff1a;CPU和CPU间的缓存&#xff0c;读写10ns级别&#xff0c;容量较大一些&#xff0c;百到千节。主存&#x…

【LeetCode笔记】33. 搜索旋转排序数组(Java、二分法)

文章目录题目描述思路 & 代码更新版题目描述 值互不相同&#xff1a;不用考虑重复值情况&#xff08;要不然比较麻烦&#xff09; 思路 & 代码 重点在于保证O(logn)的时间复杂度看成两个数组&#xff1a;前半段 & 后半段。根据两个数组的极值来判断 target 在哪…

html5版微博能收到私信吗,微博私信功能说明

新浪微博上线了私信功能&#xff0c;悄悄话也可以在微博上聊&#xff01;只要对方是你的粉丝&#xff0c;你就可以发私信给他(或者她)。例如&#xff1a;这位网友是您的粉丝&#xff0c;在他的个人首页头像下方看到“发私信”链接&#xff0c;那么我可以给他发私信。如果对方不…

linux QT 结束当前进程_Linux常用使用命令梳理

一、指定运行级别运行级别0:关机1&#xff1a;单用户2&#xff1a;多用户状态没有网络服务3&#xff1a;多用户状态有网络服务4&#xff1a;系统未使用保留状态5&#xff1a;图形界面6&#xff1a;重启系统常用的运行级别是3和5&#xff0c;要想修改运行级别&#xff0c;可以修…