[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)

posted @ 2021-12-19 23:01  CAMILIA  阅读(67)  评论(0)    收藏  举报