题目
找出数组中重复的数字。
在一个长度为 n 的数组 nums 里的所有数字都在 0~n-1 的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。
示例 1:
输入:[2, 3, 1, 0, 2, 5, 3]
输出:2 或 3
限制:2 <= n <= 100000
思路一
利用Arrays.sort()对数组进行排序,再比较两个相邻元素是否相等,如果相等就返回该元素,否则继续。
class Solution {
public int findRepeatNumber(int[] nums) {
//Step1:排序
Arrays.sort(nums);
//Step2:对于升序数组,如果当前数字与前一个字符重复则返回
for(int i = 1; i < nums.length; i++){
if(nums[i] == nums[i-1]){
return nums[i];
}
}
//Step3:如果没有重复值,输出返回值-1
return -1;
}
}
思路二
利用HashSet不能重复添加元素的性质寻找重复元素。
class Solution {
public int findRepeatNumber(int[] nums) {
//Step1:定义辅助变量
HashSet<Integer> set = new HashSet<>();
//Step2:利用hashset不能重复添加元素找出重复值
for(int num : nums){
if(!set.add(num)){
return num;
}
}
//Step3:如果找到重复值输出-1
return -1;
}
}
思路三
针对0~n-1,如果每个元素都不同,则排序后num[i] = i,因此当nums[i]!=i 寻找num[j] = i,将两个元素交换。如何找到num[j] = i,不断尝试nums[i] == nums[nums[i]]。如果在这个过程中存在两个元素相等,就返回,否则继续。
class Solution {
public int findRepeatNumber(int[] nums) {
//Step1:针对0~n-1,如果每个元素都不同,则排序后num[i] = i,
//因此当nums[i]!=i 寻找num[j] = i,将两个元素交换
//如何找到num[j] = i,不断尝试nums[i] == nums[nums[i]]
//如果在这个过程中存在两个元素相等,就返回,否则继续。
for(int i = 0; i < nums.length; i++){
while(nums[i] != i){
if(nums[i] == nums[nums[i]]){
return nums[i];
}
int tmp = nums[i];
nums[i] = nums[tmp];
nums[tmp] = tmp;
}
}
//Step2:如果找不到值返回-1
return -1;
}
}