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

方法1

先排序,再逐个比较相邻的两个元素判断

class Solution {
public:
    bool containsDuplicate(vector<int>& nums) {

        int n = nums.size();
        if(n == 0 || n == 1)
        	return false;
    	sort(nums.begin(),nums.end());
    	for(int i =1;i < n;i++)
    	{
    		if(nums[i] == nums[i-1])
    			return true;
    	}
    	return false;        
    }
};

方法2

用一个set判断是否重复

class Solution {
public:
    bool containsDuplicate(vector<int>& nums) {

    	int n = nums.size();
    	if(n == 0 || n == 1)
    		return false;
    	unordered_set<int> s(nums.begin(),nums.end());
    	return s.size()!=n;      
    }
};

posted on 2021-05-05 08:02  朴素贝叶斯  阅读(37)  评论(0编辑  收藏  举报

导航