首页 > 其他 > 详细

LeetCode刷题记录(1)—— 217. 存在重复元素

时间:2020-01-07 13:35:57      阅读:86      评论:0      收藏:0      [点我收藏+]
class Solution {
    //方法零:暴力搜索 (n^2) 超出时间限制
    /*public:
    bool containsDuplicate(vector<int>& nums) {
        for(int i=0;i<nums.size();i++){
            for(int j=i+1;j<nums.size();j++){
                if(nums[i]==nums[j]){
                    return true;
                }
            }
        }
        return false;
    }*/
    //方法一:遍历数组,将数组中每个数作为key存入map中,插入map前先查询map中是否已经含有该key,若有则数字重复(实质上也是暴力搜索)
/*  public:
    bool containsDuplicate(vector<int>& nums) {
        map<int, int> m1;
        for (auto i = nums.cbegin(); i != nums.cend(); i++) {
            auto pos = m1.find(*i);
            if(pos != m1.end()){
                return true;
            }else {
                m1[*i] = 1;
            }
        }
        return false;
    }*/
    //方法二(更优!):先对数组进行排序(nlogn),再遍历排序后数组,比较相邻的两个数是否相同
    public:
    bool containsDuplicate(vector<int>& nums) {
        if(nums.empty())
            return false;
        sort(nums.begin(), nums.end()
        );
        int temp = nums.front();
        int flag = 0;
        for(int n : nums) {
            if(n==temp&&flag==1)
                return true;
            else
                temp=n;
            flag=1;
        }
        return false;
    }
};

LeetCode刷题记录(1)—— 217. 存在重复元素

原文:https://www.cnblogs.com/esperanza/p/12160777.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!