217. 存在重复元素
一、题目
给你一个整数数组 nums
。如果任一值在数组中出现 至少两次 ,返回 true
;如果数组中每个元素互不相同,返回 false
。
二、思路
- 创建一个哈希表,然后从左往右遍历数组。
- 检测哈希表中是否已存在当前字符,若存在,直接返回结果,若不存在,将当前字符加入哈希表,供后续判断使用即可。
三、代码
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; } };
四、分析
-
时间复杂度:O(N),其中 N 为数组的长度。
-
空间复杂度:O(N),其中 N 为数组的长度。