【Python3】【力扣题】217. 存在重复元素

【力扣题】题目描述:

【Python3】代码:

1、解题思路:遍历每个元素,判断元素个数是否大于1。(此方法不适用。超出时间限制)

python 复制代码
class Solution:
    def containsDuplicate(self, nums: List[int]) -> bool:
        # 超出时间限制
        for x in nums:
            if nums.count(x) > 1:
                return True
        return False

2、解题思路:用字典形式记录每个元素的个数。判断个数是否大于1。

知识点:collections**.**Counter(...):字典子类(计数器)。记录每个元素出现的次数。

字典**.**items():返回可遍历的键值对,键值对为元组形式(键,值)。

python 复制代码
class Solution:
    def containsDuplicate(self, nums: List[int]) -> bool:
        from collections import Counter
        c = Counter(nums)
        for k,v in c.items():
            if v > 1: return True
        return False

3、解题思路:列表中元素可重复,集合中元素不重复。将列表转为集合,列表长度与集合长度不同,则存在重复元素。

知识点:set(...):转为集合。

len(...):获取序列(列表、集合等)的长度。

python 复制代码
class Solution:
    def containsDuplicate(self, nums: List[int]) -> bool:
        if len(nums) > len(set(nums)):
            return True
        return False
        # 或者
        return len(nums) > len(set(nums))
        # 或者
        return len(nums) != len(set(nums))
        

4、 解题思路:将列表排序,依次对比两个元素,相同则存在重复元素。

知识点:列表**.**sort():在原列表基础上排序。

range(n):从0到(n-1)的n个数字。即0、1、2、...、n-1。

序列[i]:序列中第i个元素。i从0开始。

python 复制代码
class Solution:
    def containsDuplicate(self, nums: List[int]) -> bool:
        nums.sort()
        for i in range(len(nums)-1):
            if nums[i] == nums[i+1]:
                return True
        return False

5、解题思路:哈希表。遍历每个元素,插入哈希表中, 若已在哈希表中,则存在重复元素。

知识点:set():创建空集合。集合中的元素不重复。

元素 in 集合:判断元素是否在集合中。

集合**.**add(...):往集合中添加元素。

python 复制代码
class Solution:
    def containsDuplicate(self, nums: List[int]) -> bool:
        s = set()
        for x in nums:
            if x in s:
                return True
            s.add(x)
        return False
相关推荐
java1234_小锋1 分钟前
TensorFlow2 Python深度学习 - 模型保存与加载
python·深度学习·tensorflow·tensorflow2
YSRM3 分钟前
Leetcode+Java+图论II
java·leetcode·图论
深蓝电商API14 分钟前
用 Selenium 搞定动态网页:模拟点击、滚动、登录全流程
爬虫·python·selenium
王六岁15 分钟前
🐍 前端开发 0 基础学 Python 入门指南:数字与字符串篇
前端·python·全栈
芒果量化17 分钟前
Optuna - 自动调参利器&python实例
开发语言·python·算法·机器学习
木头左38 分钟前
基于波动率自适应的ETF动态止盈止损模型构建与优化
python
jerryinwuhan1 小时前
pybullet入门到入门_1
开发语言·人工智能·python
景彡先生1 小时前
Python列表(List)完全指南:从入门到实战优化
windows·python·list
花开花富贵1 小时前
是谁不会表达?来看看程序员的浪漫❤ 1.1
python
java1234_小锋2 小时前
TensorFlow2 Python深度学习 - 生成对抗网络(GAN)实例
python·深度学习·tensorflow·tensorflow2