1. 两数之和 leetcode

链接

1. 两数之和 - 力扣(LeetCode)

题目

代码

解法一(暴力优化版)

python 复制代码
# 输入
nums=list(map(int,input().split()))
target=eval(input())

for i in nums:
    rem=target-i
    if rem in nums:
        print([nums.index(i),nums.index(rem)])
        break
        

特点:​

  1. ​时间复杂度:O(n²)​
    • if rem in nums 是 O(n) 的列表查找,嵌套在循环中,整体 O(n²)。
  2. ​空间复杂度:O(1)​
    • 不需要额外空间。
  3. ​潜在问题​
    • ​重复值错误​ :如 nums = [3, 3], target = 6nums.index(rem) 总是返回第一个 3 的索引,导致输出 [0, 0](错误)。
    • ​低效​:对每个元素都遍历整个数组,数据量大时速度慢。

修-避免使用同样元素

python 复制代码
# 输入
nums=list(map(int,input().split()))
target=eval(input())

for i in range(len(nums)):
    rem=target-nums[i]
    if rem in nums[i+1:]: #
        print([i,nums.index(rem,i+1)]) # 从i+1开始找
        break
        

解法二(哈希表优化版)

python 复制代码
# 输入
nums=list(map(int,input().split()))
target=eval(input())

dic={}
for k,v in enumerate(nums): # k为索引,v为值
    rem=target-v
    if rem in dic:
        print([k,dic[rem]]) 
        # 打印索引,'k'为原数组中的,'dic[rem]'为经字典存储的原数组中的
        break
    dic[v]=k    

特点:​

  1. ​时间复杂度:O(n)​
    • 只需遍历一次数组,利用字典(哈希表)实现 O(1) 的查找。
  2. ​空间复杂度:O(n)​
    • 需要额外存储字典,最坏情况下存所有元素。
  3. ​正确性高​
    • 能正确处理重复值(如 nums = [3, 3], target = 6,输出 [1, 0])。
  4. ​高效查找​
    • dic 存储已遍历的值,避免重复计算。
相关推荐
luckys.one3 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
大翻哥哥5 小时前
Python 2025:量化金融与智能交易的新纪元
开发语言·python·金融
~|Bernard|5 小时前
在 PyCharm 里怎么“点鼠标”完成指令同样的运行操作
算法·conda
战术摸鱼大师5 小时前
电机控制(四)-级联PID控制器与参数整定(MATLAB&Simulink)
算法·matlab·运动控制·电机控制
Christo35 小时前
TFS-2018《On the convergence of the sparse possibilistic c-means algorithm》
人工智能·算法·机器学习·数据挖掘
好家伙VCC6 小时前
数学建模模型 全网最全 数学建模常见算法汇总 含代码分析讲解
大数据·嵌入式硬件·算法·数学建模
zhousenshan6 小时前
Python爬虫常用框架
开发语言·爬虫·python
IMER SIMPLE6 小时前
人工智能-python-深度学习-经典神经网络AlexNet
人工智能·python·深度学习
CodeCraft Studio7 小时前
国产化Word处理组件Spire.DOC教程:使用 Python 将 Markdown 转换为 HTML 的详细教程
python·html·word·markdown·国产化·spire.doc·文档格式转换