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

相关推荐
清水白石0089 小时前
Python 编程实战全景:从基础语法到插件架构、异步性能与工程最佳实践
开发语言·python·架构
lwf0061649 小时前
导数学习日记
学习·算法·机器学习
yaoxin52112310 小时前
390. Java IO API - WatchDir 示例
java·前端·python
头发够用的程序员10 小时前
从滑动窗口到矩阵运算:img2col算法基本原理
人工智能·算法·yolo·性能优化·矩阵·边缘计算·jetson
武帝为此11 小时前
【数据清洗缺失值处理】
python·算法·数学建模
zhangchaoxies11 小时前
如何在 Go 中安全复制接口指针所指向的值
jvm·数据库·python
曲幽11 小时前
FastAPI + Pydantic 模型终极实战手册:从能跑就行到固若金汤,这些技巧你一定用得上
python·fastapi·web·model·field·pydantic·validator·basemodel
Halo_tjn11 小时前
Java 基于字符串相关知识点
java·开发语言·算法
梦想的颜色11 小时前
java 利用redis来限制用户频繁点击
java·开发语言
报错小能手11 小时前
Swift 并发 Combine响应式框架
开发语言·ios·swift