20.4.10 存在重复元素 简单

题目

给定一个整数数组,判断是否存在重复元素。
如果任意一值在数组中出现至少两次,函数返回 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. 使用map,有相同时即返回true;
  2. 还想到一种就是先排序后循环遍历。

代码

class Solution {
public:
    bool containsDuplicate(vector<int>& nums) {
        if(nums.size() == 0 || nums.size() == 1) return false;
        map<int, int> record;
        
        for(int i = 0; i < nums.size(); i++)
        {
            record[nums[i]]++;
            if(record[nums[i]] > 1) return true;
        }

        return false;
    }
};
posted @ 2020-04-10 21:03  肥斯大只仔  阅读(118)  评论(0编辑  收藏  举报