【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

hashtable[nums[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[键] = 值 # 键是数字,值是索引

相关推荐
crescent_悦1 小时前
PTA C++:正整数A+B
数据结构·c++·算法
丶小鱼丶1 小时前
数据结构和算法之【链表】
java·数据结构·算法
一直都在5721 小时前
新Java基础(二十五):异常类
java·开发语言
礼拜天没时间.1 小时前
力扣热题100实战 | 第31期:下一个排列——数组规律的极致探索
java·算法·leetcode·字典序·原地算法·力扣热题100
ws540d1 小时前
Ranking All UsersLast Updated: 2026-03-14(Sat) 19:46算法启发式活跃用户所有用户
算法
lcreek1 小时前
LeetCode LCR114.火星词典
leetcode··拓扑排序
进击的小头2 小时前
第8篇:线性二次型调节器
python·算法·动态规划
Z9fish2 小时前
sse哈工大C语言编程练习42
c语言·开发语言·算法
YYYing.2 小时前
【Linux/C++多线程篇(一) 】多线程编程入门:从核心概念到常用函数详解
linux·开发语言·c++·笔记·ubuntu