【LeetCode-05 好数对的数目 python解法】

代码:

基础解法:两个for循环进行比较,挨个比较。

这需要 O(n *n)的时间。

复制代码
class Solution:
    def numIdenticalPairs(self, nums: List[int]) -> int:
        sum = 0
        for i in range(len(nums)):
            for j in range(i+1, len(nums)):
                if nums[i] == nums[j]:
                    sum = sum+1
        return sum

优化解法:


复制代码
class Solution:
    def numIdenticalPairs(self, nums: List[int]) -> int:
        ans = 0                          # 好数对的数量
        cnt = defaultdict(int)            # 创建默认字典,默认值为0
        for x in nums:                    # 遍历数组,x = nums[j]
            # 此时 cnt[x] 表示之前遍历过的 x 的个数,加到 ans 中
            ans += cnt[x]                 # 关键:先加,后存
            cnt[x] += 1                   # 把当前 x 存入字典
        return ans

将题目中数组的数据存入到创建的字典中,字典中:键是数据的标签,值是标签对应的数据。字典的结构就是 {键1: 值1, 键2: 值2, ...}。键是唯一的,不能重复的,否则值会被覆盖。

总结:遇到这种问题,均可用此法,时间复杂度和空间复杂度都是o(n)。理解字典的值和键关系

相关推荐
季远迩2 小时前
73.矩阵置零(中等)
算法
做一个码农都是奢望2 小时前
计算机控制系统课程CH3:数字控制系统闭环响应分析与 MATLAB 实现
人工智能·算法·matlab
爱玩亚索的程序员2 小时前
算法入门(三)学会用matplotlib画图
算法·matplotlib
請你喝杯Java2 小时前
Python 后端开发:从虚拟环境、pip、requirements.txt 到项目启动
开发语言·python·pip
一叶落4382 小时前
LeetCode 6. Z 字形变换(C语言详解)
c语言·数据结构·算法·leetcode
YFLICKERH2 小时前
【Python-Web后端开发框架】Flask | Django | FastAPI | Tornado 选型与 使用 | 特性
前端·python·flask
啊董dong2 小时前
noi-2026年3月17号作业
数据结构·c++·算法
2401_831920742 小时前
Python生成器(Generator)与Yield关键字:惰性求值之美
jvm·数据库·python
2401_874732532 小时前
泛型编程与STL设计思想
开发语言·c++·算法