题目
给你一个整数数组 nums 。如果任一值在数组中出现 至少两次 ,返回 true ;如果数组中每个元素互不相同,返回 false 。
Sample
input:nums = [1,2,3,1]
output:true
input:nums = [1,2,3,4]
output:false
input:nums = [1,1,1,3,3,4,3,2,4,2]
output:true
Hint
1 <= nums.length <= 105
-109 <= nums[i] <= 109
题面分析
Set
set会删去重复元素,再比较set和num的size即可
class Solution {
public:
bool containsDuplicate(vector<int>& nums) {
return set<int>(nums.begin(),nums.end()).size()!=nums.size();
}
};
Hash
遍历所有元素,如果容器内已有该元素,则重复;否则插遍历元素入unodered_set容器
class Solution {
public:
bool containsDuplicate(vector<int>& nums) {
unordered_set<int>s;
for(int x: nums){
if(s.find(x) != s.end()) return true;
s.insert(x);
}
return false;
}
};