"剑指offer(Java)2: 数组中重复的数字"
剑指 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 题的一个详细总结。
剩余119页未读,继续阅读
- 粉丝: 30
- 资源: 321
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- JDK 17 Linux版本压缩包解压与安装指南
- C++/Qt飞行模拟器教员控制台系统源码发布
- TensorFlow深度学习实践:CNN在MNIST数据集上的应用
- 鸿蒙驱动HCIA资料整理-培训教材与开发者指南
- 凯撒Java版SaaS OA协同办公软件v2.0特性解析
- AutoCAD二次开发中文指南下载 - C#编程深入解析
- C语言冒泡排序算法实现详解
- Pointofix截屏:轻松实现高效截图体验
- Matlab实现SVM数据分类与预测教程
- 基于JSP+SQL的网站流量统计管理系统设计与实现
- C语言实现删除字符中重复项的方法与技巧
- e-sqlcipher.dll动态链接库的作用与应用
- 浙江工业大学自考网站开发与继续教育官网模板设计
- STM32 103C8T6 OLED 显示程序实现指南
- 高效压缩技术:删除重复字符压缩包
- JSP+SQL智能交通管理系统:违章处理与交通效率提升