自己的方案(超时)
1.数组快排
2.逐一检查
问题:超时问题严重,用了递归,空间代价太大
大神题解
利用HashSet存储的无序不可重复数据的特性轻松解决。
为什么自己没有想到?
答:集合好久没复习了,忘了set接口的特性
首先贴出解决方案
class Solution {
public int findRepeatNumber(int[] nums) {
HashSet hashSet = new HashSet<>();
for (int i = 0; i < nums.length; i++) {
if(!hashSet.add(nums[i])) {
return nums[i];
}
}
return -1;
}
}
以上为官方题解
顺便复习一下HashSet,先看下图层级关系
添加元素的过程:以HashSet为例:
我们向HashSet中添加元素a,首先调用元素a所在类的hashCode()方法,计算元素a的哈希值,
此哈希值接着通过某种算法计算出在HashSet底层数组中的存放位置(即为:索引位置),判断
数组此位置上是否已经有元素:
如果此位置上没有其他元素,则元素a添加成功。 —>情况1
如果此位置上有其他元素b(或以链表形式存在的多个元素),则比较元素a与元素b的hash值:
如果hash值不相同,则元素a添加成功。—>情况2
如果hash值相同,进而需要调用元素a所在类的equals()方法:
equals()返回true,元素a添加失败
equals()返回false,则元素a添加成功。—>情况3
对于添加成功的情况2和情况3而言:元素a 与已经存在指定索引位置上数据以链表的方式存储。