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

每日算法 -【Swift 算法】三数之和最接近目标值

🚀 Swift 实现:三数之和最接近目标值(3Sum Closest)

✨ 前言

在算法学习过程中,经典的“三数之和”系列题目是很多人通往进阶路上的一道坎。今天我们来介绍其中一个非常实用的变种问题 —— 三数之和最接近目标值(3Sum Closest),并使用 Swift 实现一个高效的解法。


📌 问题描述

给定一个包含 n 个整数的数组 nums 和一个目标值 target,请从数组中找出 三个整数,使得它们的和最接近 target,返回这个最接近的和。

假设每组输入只存在唯一解

示例:

输入: nums = [-1, 2, 1, -4], target = 1
输出: 2
解释: 最接近目标值 1 的和是 2-1 + 2 + 1 = 2

🔍 解题思路

我们使用经典的 排序 + 双指针 思路,整体时间复杂度为 O(n^2)

  1. 先对数组进行排序,以便后续使用双指针。
  2. 从左到右遍历数组,固定一个数 nums[i]
  3. 使用两个指针 left = i + 1right = n - 1,在剩余的区间中找出两个数,使得三个数之和最接近目标值。
  4. 用一个变量 closestSum 来持续更新当前找到的最接近的和。
  5. 如果三数之和正好等于目标值,直接返回即可。

🧠 边界注意

  • 为防止数组越界,我们确保数组长度至少为 3。
  • 使用 abs(currentSum - target) 与当前最优解进行比较,更新最接近的和。

✅ Swift 实现代码

func threeSumClosest(_ nums: [Int], _ target: Int) -> Int {guard nums.count >= 3 else {fatalError("数组长度必须至少为 3")}let nums = nums.sorted()let n = nums.countvar closestSum = nums[0] + nums[1] + nums[2]for i in 0..<n - 2 {var left = i + 1var right = n - 1while left < right {let currentSum = nums[i] + nums[left] + nums[right]if abs(currentSum - target) < abs(closestSum - target) {closestSum = currentSum}if currentSum < target {left += 1} else if currentSum > target {right -= 1} else {return target  // 最优解,直接返回}}}return closestSum
}

🧪 示例测试

let nums = [-1, 2, 1, -4]
let target = 1
let result = threeSumClosest(nums, target)
print("最接近的三数之和为:\(result)")
// 输出:最接近的三数之和为:2

📈 时间与空间复杂度分析

  • 时间复杂度O(n^2),排序是 O(nlogn),双指针循环是 O(n^2)
  • 空间复杂度O(1),使用了常数额外空间。

🧵 小结

本题不仅锻炼了我们处理数组问题的能力,也考察了我们在排序基础上的双指针技巧。Swift 在处理这类算法问题时,同样可以非常清晰简洁地实现逻辑。

如果你正在准备算法面试,这类“固定一个数 + 双指针”的套路一定要熟练掌握!


💬 欢迎交流

如果你觉得这篇文章对你有帮助,不妨点个赞、收藏或留言交流更多 Swift 算法题目,感谢你的阅读 🙌!

http://www.lqws.cn/news/163999.html

相关文章:

  • 高敏感应用如何保护自身不被逆向?iOS 安全加固策略与工具组合实战(含 Ipa Guard 等)
  • wxpython快捷键示例
  • SpringBoot3整合MySQL8的注意事项
  • 云服务器自带的防御可靠吗
  • 使用 minicom 录制串口报文并回放
  • 数据融合是什么?进行数据融合的4大关键环节!
  • AI开启光伏新时代:精准计算每小时发电量​
  • 【JS进阶】ES5 实现继承的几种方式
  • 微软认证考试科目众多?该如何选择?
  • 基于SpringBoot的房屋租赁系统的设计与实现(thymeleaf+MySQL)
  • IDEA202403 设置主题和护眼色
  • 【QT】qtdesigner中将控件提升为自定义控件后,css设置样式不生效(已解决,图文详情)
  • C# 委托UI控件更新例子,何时需要使用委托
  • Agentic AI 和 Agent AI 到底区别在哪里?
  • Redis大量key集中过期怎么办
  • Qt 开发中的父类与父对象的区别和父对象传递:如何选择 `QWidget` 或 `QObject`?
  • 基于Canvas实现画布
  • Spring Boot+Neo4j知识图谱实战:3步搭建智能关系网络!
  • 西门子SCL之IF-ELSIF语句详解及应用(安全控制代码)
  • 【计组】真题 2015 大题
  • Vue---vue使用AOS(滚动动画)库
  • 分布式光纤传感(DAS)技术应用解析:从原理到落地场景
  • 【QT】使用QT帮助手册找控件样式
  • 基于责任链模式进行订单参数的校验
  • 自动化办公集成工具:一站式解决文档处理难题
  • React Router 中 navigate 后浏览器返回按钮不起作用的问题记录
  • React Hooks 基础指南
  • 如果科技足够发达,是否还需要维持自然系统(例如生物多样性)中那种‘冗余’和‘多样性’,还是可以只保留最优解?
  • Python数据可视化科技图表绘制系列教程(四)
  • 动静态库的使用(Linux下)