数组中重复的数字
题目连接
找出数组中重复的数字。
在一个长度为 n
的数组 nums
里的所有数字都在 0~n-1
的范围内。数组中某些数字是重复的,但不知道有几个数字重复了,也不知道每个数字重复了几次。请找出数组中任意一个重复的数字。
示例 1:
输入:
[2, 3, 1, 0, 2, 5, 3]
输出:2 或 3
限制:
2 <= n <= 100000
解题思路
思路1
- 排序。
- 再遍历数组,判断相邻两个数是否相同。
- 时间复杂度: O ( n l o g n ) O(nlogn) O(nlogn),空间复杂度: O ( n ) O(n) O(n)
思路2
- 使用map计算每个元素出现次数
- 时间复杂度: O ( n ) O(n) O(n),空间复杂度: O ( n ) O(n) O(n)
思路3
- 因为题目限定了每个数字在
0~n-1
之间,那么将每个数字交换到自己应该在的位置即可。 - 比方说当前的索引为
i=0
,数字是3
,理论上它应该在索引为3
的位置上,却被nums[nums[i]]
占有。那么我们执行swap(nums[i],nums[nums[i]])
。 - 执行完一次交换,3的位置是对了,但是和3交换后的数字nums[i]的位置可能还是不正确。
- 所以应该使用
while
循环,循环结束条件为nums[i]!=nums[nums[i]]
。 - 最后判断下
i!=nums[i]
,不等于即为重复的数字。 - 时间复杂度: O ( n ) O(n) O(n),空间复杂度: O ( 1 ) O(1) O(1)
解题代码1:
#include<iostream>
#include<cstdlib>
#include<algorithm>
#include<vector>
#include<map>
using namespace std;
class Solution {
public:
int findRepeatNumber(vector<int>& nums) {
int ans=0;
sort(nums.begin(),nums.end());
for(int i=0;i<nums.size()-1;i++){
if(nums[i]==nums[i+1]){
ans=nums[i];
break;
}
}
return ans;
}
};
int main(){
vector<int>nums = {3,4,2,1,1,0};
Solution so = Solution();
cout<<so.findRepeatNumber(nums)<<endl;
return 0;
}
解题代码2:
#include<iostream>
#include<cstdlib>
#include<algorithm>
#include<vector>
#include<map>
using namespace std;
class Solution {
public:
int findRepeatNumber(vector<int>& nums) {
int ans=0;
map<int,int>vis;
for(int i=0;i<nums.size();i++){
vis[nums[i]]+=1;
if(vis[nums[i]]>1)return nums[i];
}
return ans;
}
};
int main(){
vector<int>nums = {3,4,2,1,1,0};
Solution so = Solution();
cout<<so.findRepeatNumber(nums)<<endl;
return 0;
}
解题代码3:
#include<iostream>
#include<cstdlib>
#include<algorithm>
#include<vector>
#include<map>
using namespace std;
class Solution {
public:
int findRepeatNumber(vector<int>& nums) {
int ans=0;
for(int i=0;i<nums.size();i++){
if(i!=nums[i]){
while(nums[i]!=nums[nums[i]]){
swap(nums[i],nums[nums[i]]);
}
}
if(nums[i]!=i){
ans=nums[i];
break;
}
}
return ans;
}
};
int main(){
vector<int>nums = {3,4,2,1,1,0};
Solution so = Solution();
cout<<so.findRepeatNumber(nums)<<endl;
return 0;
}