【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
相关推荐
fantasy_arch1 小时前
pytorch例子计算两张图相似度
人工智能·pytorch·python
WBluuue3 小时前
数学建模:智能优化算法
python·机器学习·数学建模·爬山算法·启发式算法·聚类·模拟退火算法
赴3353 小时前
矿物分类案列 (一)六种方法对数据的填充
人工智能·python·机器学习·分类·数据挖掘·sklearn·矿物分类
大模型真好玩4 小时前
一文深度解析OpenAI近期发布系列大模型:意欲一统大模型江湖?
人工智能·python·mcp
RPA+AI十二工作室4 小时前
亚马逊店铺绩效巡检_影刀RPA源码解读
chrome·python·rpa·影刀
小艳加油4 小时前
Python机器学习与深度学习;Transformer模型/注意力机制/目标检测/语义分割/图神经网络/强化学习/生成式模型/自监督学习/物理信息神经网络等
python·深度学习·机器学习·transformer
Swift社区5 小时前
Swift 实战:实现一个简化版的 Twitter(LeetCode 355)
leetcode·swift·twitter
学行库小秘6 小时前
ANN神经网络回归预测模型
人工智能·python·深度学习·神经网络·算法·机器学习·回归
Yn3126 小时前
在 Python 中使用 json 模块的完整指南
开发语言·python·json
秋难降6 小时前
线段树的深度解析(最长递增子序列类解题步骤)
数据结构·python·算法