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

相关推荐
wj3055853787 小时前
课程 9:模型测试记录与 Prompt 策略
linux·人工智能·python·comfyui
为何创造硅基生物8 小时前
C语言 结构体内存对齐规则(通俗易懂版)
c语言·开发语言
吃好睡好便好8 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
星寂樱易李8 小时前
iperf3 + Python-- 网络带宽、网速、网络稳定性
开发语言·网络·python
仰泳之鹅8 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
qingfeng154158 小时前
企业微信机器人开发:如何实现自动化与智能运营?
人工智能·python·机器人·自动化·企业微信
之歆9 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
cen__y10 小时前
Linux12(Git01)
linux·运维·服务器·c语言·开发语言·git
AI人工智能+电脑小能手10 小时前
【大白话说Java面试题 第65题】【JVM篇】第25题:谈谈对 OOM 的认识
java·开发语言·jvm