每日算法 -【Swift 算法】Two Sum 问题:从暴力解法到最优解法的演进

【Swift 算法】Two Sum 问题:从暴力解法到最优解法的演进

本文通过"Two Sum"问题,带你了解如何从最直观的暴力解法,逐步优化到高效的哈希表解法,并对两者进行对比,适合算法入门和面试准备。


💡 问题描述

给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 的那两个整数,并返回它们的数组下标。

你可以假设每种输入只会对应一个答案。
不能使用同一个元素两次。


🪓 解法一:暴力枚举(Brute Force)

🧠 思路:

  • 使用两层循环,枚举所有可能的两两组合。
  • 判断它们的和是否等于 target
  • 一旦找到即返回。

💻 代码实现:

swift 复制代码
func twoSumBruteForce(_ nums: [Int], _ target: Int) -> [Int] {
    for i in 0..<nums.count {
        for j in i + 1..<nums.count {
            if nums[i] + nums[j] == target {
                return [i, j]
            }
        }
    }
    return []
}

⏱ 时间复杂度:

  • O(n²):两层循环遍历所有组合。

☁️ 空间复杂度:

  • O(1):只用了常量空间。

✅ 示例:

swift 复制代码
let nums = [2, 7, 11, 15]
let target = 9
print(twoSumBruteForce(nums, target)) // 输出: [0, 1]

⚡ 解法二:哈希表(最优解法)

🧠 思路:

  • 用一个字典记录"元素值 ➜ 索引"。
  • 遍历数组时,计算目标值与当前元素的差值 complement = target - num
  • 判断这个差值是否已经出现在字典中,如果是,说明找到了。

💻 代码实现:

swift 复制代码
func twoSum(_ nums: [Int], _ target: Int) -> [Int] {
    var numToIndex = [Int: Int]()
    for (index, num) in nums.enumerated() {
        let complement = target - num
        if let complementIndex = numToIndex[complement] {
            return [complementIndex, index]
        }
        numToIndex[num] = index
    }
    return []
}

⏱ 时间复杂度:

  • O(n):只遍历一遍数组,每次查找/插入都是常数时间。

☁️ 空间复杂度:

  • O(n):用了一个哈希表来存储元素。

✅ 示例:

swift 复制代码
let nums = [2, 7, 11, 15]
let target = 9
print(twoSum(nums, target)) // 输出: [0, 1]

📊 总结对比

解法 时间复杂度 空间复杂度 特点
暴力解法 O(n²) O(1) 简单易懂,适合初学者
哈希表解法 O(n) O(n) 性能更高,适合大数据、面试场景

相关推荐
智者知已应修善业13 分钟前
【51单片机2个外部中断切换LED花样】2024-1-3
c++·经验分享·笔记·算法·51单片机
陕西企来客18 分钟前
2026 西安 GEO 优化技术解析:前沿技术与行业规范深度企来客科技行业白皮书声明
开发语言·搜索引擎·php
8Qi819 分钟前
LeetCode 31:下一个排列(Next Permutation)—— 完整题解笔记 ✅
笔记·算法·leetcode·指针·思维·排列
AI科技星21 分钟前
基于光速螺旋第一性原理:$G,\varepsilon_0,\alpha$引电统一完整推导+严谨证明+高精度数值全维度分析
c语言·开发语言·网络·量子计算·agi
春日见23 分钟前
五分钟入门强化学习DDPG
大数据·人工智能·算法·机器学习·计算机视觉
vivo互联网技术36 分钟前
ICLR 2026 | LiveMoments 用参考图引导的扩散模型提升重选封面帧画质
人工智能·算法·aigc技术探索
落羽的落羽37 分钟前
【算法札记】练习 | Week5
linux·服务器·c++·人工智能·计算机网络·算法·哈希算法
人月神话-Lee42 分钟前
【图像处理】图像直方图——从“频率分布“到“智能决策“
图像处理·人工智能·ios·ai编程·swift
淘矿人1 小时前
DeepSeek V4对决Claude 4.8:AI模型终极横评
java·开发语言·人工智能·python·sql·php·pygame