"剑指offer(Java)2: 数组中重复的数字"
需积分: 0 38 浏览量
更新于2024-01-20
收藏 1.71MB PDF 举报
剑指 Offer 第二版中的第 2 题是要求找出数组中重复的数字。给定一个长度为 n 的数组 nums,其中的数字都在 0~n-1 的范围内。数组中可能有重复的数字,但不知道有几个数字重复了,也不知道每个数字重复了几次。要求找出数组中任意一个重复的数字。
给定一个示例数组 [2, 3, 1, 0 , 2, 5, 3],我们要找到其中一个重复的数字。在这个示例中,重复的数字有 2 和 3。
为了解决这个问题,我们可以使用一个 hash 表来存储已经遍历过的数字,当遍历到一个数字时,如果已经存在于 hash 表中,则说明该数字是重复的。我们可以使用一个 set 来模拟一个 hash 表,使用 set.add() 方法来添加数字,如果添加失败,则说明该数字已经存在于 set 中,即是重复数字。我们可以将重复数字赋给一个变量 res,并返回 res。
具体的代码如下:
```java
class Solution {
public int findRepeatNumber(int[] nums) {
// 使用一个 set 来模拟一个 hash 表
Set<Integer> set = new HashSet<Integer>();
int res = -1;
for(int num : nums) {
// 尝试将 num 添加到 set 中,如果添加失败,则说明 num 已经存在于 set 中,即是重复数字
if(!set.add(num)) {
res = num;
break;
}
}
return res;
}
}
```
这段代码的时间复杂度为 O(n),其中 n 是数组的长度。由于使用了一个 set 来存储已经遍历过的数字,所以空间复杂度也为 O(n)。
该题目要求找出数组中任意一个重复的数字,所以使用 hash 表即可解决。可以在遍历数组的过程中不断将数字添加到 set 中,如果添加失败,则说明该数字重复了,可以直接返回该数字作为结果。
以上是对剑指 Offer 第二版中第 2 题的一个详细总结。
2021-05-09 上传
2024-11-04 上传
2024-11-04 上传
2024-11-04 上传
yiyi分析亲密关系
- 粉丝: 32
- 资源: 321
最新资源
- Aspose资源包:转PDF无水印学习工具
- Go语言控制台输入输出操作教程
- 红外遥控报警器原理及应用详解下载
- 控制卷筒纸侧面位置的先进装置技术解析
- 易语言加解密例程源码详解与实践
- SpringMVC客户管理系统:Hibernate与Bootstrap集成实践
- 深入理解JavaScript Set与WeakSet的使用
- 深入解析接收存储及发送装置的广播技术方法
- zyString模块1.0源码公开-易语言编程利器
- Android记分板UI设计:SimpleScoreboard的简洁与高效
- 量子网格列设置存储组件:开源解决方案
- 全面技术源码合集:CcVita Php Check v1.1
- 中军创易语言抢购软件:付款功能解析
- Python手动实现图像滤波教程
- MATLAB源代码实现基于DFT的量子传输分析
- 开源程序Hukoch.exe:简化食谱管理与导入功能