【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
相关推荐
阿俊仔(摸鱼版)23 分钟前
Python 常用运维模块之OS模块篇
运维·开发语言·python·云服务器
lly_csdn1231 小时前
【Image Captioning】DynRefer
python·深度学习·ai·图像分类·多模态·字幕生成·属性识别
西猫雷婶1 小时前
python学opencv|读取图像(四十一 )使用cv2.add()函数实现各个像素点BGR叠加
开发语言·python·opencv
金融OG1 小时前
99.11 金融难点通俗解释:净资产收益率(ROE)VS投资资本回报率(ROIC)VS总资产收益率(ROA)
大数据·python·算法·机器学习·金融
小唐C++3 小时前
C++小病毒-1.0勒索
开发语言·c++·vscode·python·算法·c#·编辑器
醇醛酸醚酮酯3 小时前
Leetcode热题——移动零
算法·leetcode·职场和发展
夏末秋也凉3 小时前
力扣-数组-704 二分查找
算法·leetcode
北 染 星 辰3 小时前
Python网络自动化运维---用户交互模块
开发语言·python·自动化
qy发大财3 小时前
平衡二叉树(力扣110)
数据结构·算法·leetcode·职场和发展
codists3 小时前
《CPython Internals》阅读笔记:p336-p352
python