【LeetCode-01 两数之和 python解法】

#1.两数之和

第一种粗暴解法:两个for循环

复制代码
class Solution:
    def twoSum(self, nums: List[int], target: int) -> List[int]:
        mylist = []
        n = len(nums)

        for i in range(n): 
            for j in range(i+1, n):
                if nums[i] + nums[j] == target:
                    mylist.append(i)
                    mylist.append(j)
                    return mylist
        
        return mylist

第二种解法:哈希表法

复制代码
class Solution:
    def twoSum(self, nums: List[int], target: int) -> List[int]:
        hashtable = dict() #定义字典
        for i, num in enumerate(nums): #同时获取列表的索引和值
            if target - num in hashtable: #第一个数值肯定不在字典hashtable中,则存入
                return [hashtable[target - num], i]
            hashtable[nums[i]] = i
        return []

完整的执行过程演示:以 nums = 2,7,11,15, target = 9 为例:

初始状态:字典 hashtable = {}(空的)

第1次循环(i=0, num=2)

target - num = 9-2 = 7 需要的数是 7

if 7 in hashtable: #检查 7 在字典中吗? 字典是 {},没有 7

hashtablenums\[0] = 0 #把 2:0 存入字典 字典变成 {2:0}

第2次循环(i=1, num=7)

target - num = 9-7 = 2 需要的数是 2

if 2 in hashtable: #检查 2 在字典中吗? 字典是 {2:0},有 2

return hashtable\[2, 1] 返回 0, 1

题外标注:字典存入数据方法:直接赋值 dict = 值 # 键是数字,值是索引

相关推荐
财经资讯数据_灵砚智能10 小时前
基于全球经济类多源新闻的NLP情感分析与数据可视化(夜间-次晨)2026年6月9日
人工智能·python·ai·信息可视化·自然语言处理·ai编程·灵砚智能
仙俊红10 小时前
深入理解 ThreadLocal —— 从变量引用、强弱引用到 Spring Boot 实战
spring boot·python·算法
Anastasiozzzz10 小时前
构建健壮软件系统的基石:深入解析面向对象设计七大原则
开发语言·javascript·设计模式·ecmascript
故渊at10 小时前
第五板块:Android 系统服务与电源管理 | 第十八篇:Battery Service 与 电量统计(Fuel Gauge)算法
android·算法·battery·电源·电池·电源管理·电量统计
Dxy123931021610 小时前
Python 请求:为什么 Session 比直接请求快 10 倍?
开发语言·python
The_Ticker10 小时前
港股量化实测:实时行情接口性能与数据质量深度解析
python·websocket·算法·金融
weisian15110 小时前
基础篇--概念原理-25-大模型的剪枝是什么?怎么理解?——从原理到实战,一篇讲透
算法·机器学习·大模型·剪枝
dongf201910 小时前
R 语言 逻辑斯蒂回归
开发语言·数据分析·回归·r语言
fie888910 小时前
基于有限体积法(FVM)的MATLAB流体力学求解程序
算法·matlab
Irissgwe10 小时前
C++ STL unordered系列关联式容器详解
开发语言·c++·stl·关联式容器