当前位置: 首页 > news >正文

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

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

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


💡 问题描述

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

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


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

🧠 思路:

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

💻 代码实现:

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):只用了常量空间。

✅ 示例:

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

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

🧠 思路:

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

💻 代码实现:

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

⏱ 时间复杂度:

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

☁️ 空间复杂度:

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

✅ 示例:

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

📊 总结对比

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

http://www.dtcms.com/a/192096.html

相关文章:

  • 《数字藏品社交化破局:React Native与Flutter的创新实践指南》
  • Python----神经网络(基于DNN的风电功率预测)
  • 桃芯ingchips——windows HID键盘例程无法同时连接两个,但是安卓手机可以的问题
  • 问题处理——在ROS2(humble)+Gazebo+rqt下,无法显示仿真无人机的相机图像
  • 三目云台20倍变焦智能监控技术
  • Nginx 返回 504 状态码表示 网关超时(Gateway Timeout)原因排查
  • 金融量化智能体,如何开发一个有效的策略?
  • C++中委托构造函数(delegating constructor)详解和注意事项
  • elementUI 循环出来的表单,怎么做表单校验?
  • InforSuite RDS 与django结合
  • React事件机制
  • 解决 Conda 安装 PyTorch 1.1.0 报错:excluded by strict repo priority(附三种解决方案)
  • [特殊字符]川翔云电脑:重新定义云端算力新纪元
  • 【爬虫】DrissionPage-3
  • 力扣-49.字母异位词分组
  • 10.2 LangChain v0.3全面解析:模块化架构+多代理系统如何实现效率飙升500%
  • 如何安全擦除 SSD 上的可用空间
  • 牛客网NC231954:斐波那契数列 (简单的数列问题)
  • Ubuntu离线安装Minio
  • DeepSeek模型架构详解:从Transformer到MoE
  • ‌JMeter聚合报告中的任务数和并发数区别
  • 【AI News | 20250515】每日AI进展
  • 数据结构——例题3
  • Function Calling
  • 【LLIE专题】基于码本先验与生成式归一化流的低光照图像增强新方法
  • OpenHarmony 5.1.0 Release目录结构详细解析(3级目录)
  • 解读RTOS 第八篇 · 内核源码解读:以 FreeRTOS 为例
  • AAC 协议
  • MyBatis 的分页插件 c
  • 交通运输与能源融合发展——光储充在交通上的应用完整解决方案