leetcode做题笔记217. 存在重复元素

给你一个整数数组 nums 。如果任一值在数组中出现 至少两次 ,返回 true ;如果数组中每个元素互不相同,返回 false

示例 1:

复制代码
输入:nums = [1,2,3,1]
输出:true

示例 2:

复制代码
输入:nums = [1,2,3,4]
输出:false

示例 3:

复制代码
输入:nums = [1,1,1,3,3,4,3,2,4,2]
输出:true

思路一:集合

c++解法

cpp 复制代码
class Solution
{
public:
    bool containsDuplicate(vector<int> &nums)
    {
        return (std::set<int>(nums.begin(), nums.end()).size() != nums.size());
    }
};

分析:

直接用集合将重复数字剔除,最后比较两个数组之间的长度,若不等则返回false

思路二:排序后遍历

c++解法

cpp 复制代码
class Solution {
public:
    bool containsDuplicate(vector<int>& nums) {
        sort(nums.begin(),nums.end());
        for(int i = 0;i < nums.size() - 1;i++)
            if(nums[i] == nums[i+1]) return true;
        return false;
    }
};

分析:

将数组排序后只需查看相邻的两个数是否相等即可判断,时间复杂度为O(nlogn)

总结:

本题考察对排序,集合的应用,利用相关性质即可解决

相关推荐
计算机安禾几秒前
【数据结构与算法】第15篇:队列(二):链式队列的实现与应用
c语言·开发语言·数据结构·c++·学习·算法·visual studio
丝斯20111 分钟前
AI学习笔记整理(78)——Python学习7
人工智能·笔记·学习
唯_ww2 分钟前
COMSOL学习笔记(一)曲线图数据导出及画图
笔记·学习
算法鑫探10 分钟前
C语言密码验证:3次机会解锁
c语言·数据结构·算法·新人首发
我没想到原来他们都是一堆坏人10 分钟前
SQL 表结构定义(索引与约束)学习笔记一——索引、外键与级联约束
笔记·sql·学习
穿条秋裤到处跑24 分钟前
每日一道leetcode(2026.03.30):判断通过操作能否让字符串相等 II
算法·leetcode
Q741_14725 分钟前
每日一题 力扣 2840. 判断通过操作能否让字符串相等 II 力扣 2839. 判断通过操作能否让字符串相等 I 找规律 字符串 C++ 题解
c++·算法·leetcode·力扣·数组·找规律
xu_wenming30 分钟前
在 TinyML 场景下,如何将模型从 FP32 量化为 INT8?
arm开发·算法·iot
csdn_aspnet33 分钟前
C++ 求n边凸多边形的对角线数量(Find number of diagonals in n sided convex polygon)
开发语言·c++·算法
深邃-1 小时前
字符函数和字符串函数(1)
c语言·开发语言·数据结构·c++·算法·html5