[LeetCode]-217.存在重复元素-简单
217. 存在重复元素
给定一个整数数组,判断是否存在重复元素。
如果存在一值在数组中出现至少两次,函数返回 true 。如果数组中每个元素都不相同,则返回 false 。
示例 1:
输入: [1,2,3,1]
输出: true
示例 2:
输入: [1,2,3,4]
输出: false
示例 3:
输入: [1,1,1,3,3,4,3,2,4,2]
输出: true
通过次数428,800 提交次数772,142
一道很常见的基础题,作为熟悉LeetCode的开始,重点放在熟悉其对于算法的表达方式。
C++题解1:
排序后遍历,如果有重复则return退出。
LeetCode中C++
可变数组:vector<int>& array
数组开头:array.begin()
数组结尾:array.end()
数组大小:array.size()
时间复杂度:自带排序函数sort()_O(nlogn) + 遍历O(n)
class Solution {
public:
bool containsDuplicate(vector<int>& nums) {
sort(nums.begin(), nums.end());
for (int i = 1; i < nums.size(); i++){
if (nums[i] == nums[i - 1])
return true;
}
return false;
}
};
C++题解2:
哈希的思想,遍历并且插入哈希表,如果已占位则return退出。
这里用到了STL的unordered_set
,初步理解为set集合,拥有去重的特性。
增insert()
、删erase()
、查find()
复杂度与哈希表相同,均为O(1)。
时间复杂度:O(n) 最坏情况在遍历一遍都没有重复时
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;
}
};
这里看出数组上的for循环可以写作for (int x: nums)
。