【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)。理解字典的值和键关系

相关推荐
llm大模型算法工程师weng5 小时前
Python拉取视频流的性能优化实战
开发语言·python·性能优化
机器学习之心5 小时前
信号分解和小波阈值联合降噪 | NRBO-FMD基于牛顿拉夫逊算法优化特征模态分解+皮尔逊系数+小波阈值降噪+信号重构,MATLAB代码
算法·matlab·重构·nrbo-fmd·特征模态分解
Lauren_Blueblue5 小时前
第十六届蓝桥杯省赛Python研究生组-F串
python·算法·蓝桥杯·算法基础
kaico20185 小时前
面向对象和高级特性
开发语言·python
曲幽5 小时前
告别手写 API 胶水代码:FastAPI 与 Vue 的“契约自动机” OpenAPI 实战
python·typescript·vue·fastapi·web·swagger·openapi·codegen
鲸渔5 小时前
【C++ 入门】第一个程序:Hello World 与基本语法规则
开发语言·c++·算法
‎ദ്ദിᵔ.˛.ᵔ₎5 小时前
滑动窗口算法
算法·哈希算法
阿捞25 小时前
python-langchain框架(3-20-智能问答ZeroShot_ReAct Agent 从零搭建)
python·react.js·langchain
数据知道5 小时前
claw-code 源码分析:从 REPL 到服务端——CLI / HTTP(SSE) / LSP 多入口如何共享同一颗 runtime 心?
python·网络协议·http·ai·里氏替换原则·claude code
sali-tec5 小时前
C# 基于OpenCv的视觉工作流-章46-矩形卡尺
图像处理·人工智能·opencv·算法·计算机视觉