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

相关推荐
taWSw5OjU5 小时前
vue对接海康摄像头-H5player
开发语言·前端·javascript
格林威5 小时前
工业相机异常处理实战:断连重连、丢帧检测、超时恢复状态机
开发语言·人工智能·数码相机·计算机视觉·视觉检测·机器视觉·工业相机
菜鸟‍5 小时前
【论文学习】Disco:基于邻接感知协同着色的密集重叠细胞实例分割方法
人工智能·学习·算法
Gse0a362g5 小时前
Go - Zerolog使用入门
开发语言·后端·golang
KhalilRuan5 小时前
Burst编译器的底层原理
java·开发语言
牧天白衣.5 小时前
力扣215.数组中的第K个最大元素
算法·leetcode
Shirley~~5 小时前
力扣hot100:每日温度
开发语言·javascript·ecmascript
qZ6bgMe435 小时前
使用Mixin类简单重构配置模块
网络·python·重构
巧妹儿5 小时前
AI Agent 实战:MySQL 监控指标查询 Skill|华为云 + 腾讯云双兼容可直接复用
python·mysql·ai·大模型·华为云·腾讯云
cxr8285 小时前
控制理论基础
人工智能·算法