0
点赞
收藏
分享

微信扫一扫

Leetcode217.存在重复元素

他说Python 2022-01-28 阅读 83

题目

给你一个整数数组 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;
    }
};

举报

相关推荐

0 条评论