算法每日一练 (10)

ops/2025/3/15 3:31:34/

💢欢迎来到张胤尘的技术站
💥技术如江河,汇聚众志成。代码似星辰,照亮行征程。开源精神长,传承永不忘。携手共前行,未来更辉煌💥

文章目录

  • 算法每日一练 (10)
    • 最接近的三数之和
      • 题目描述
      • 解题思路
      • 解题代码
        • `c/c++`
        • `golang`
        • `lua`

官方站点: 力扣 Leetcode

算法每日一练 (10)

最接近的三数之和

题目地址:最接近的三数之和

题目描述

给你一个长度为 n 的整数数组 nums 和 一个目标值 target。请你从 nums 中选出三个整数,使它们的和与 target 最接近。

返回这三个数的和。

假定每组输入只存在恰好一个解。

示例 1:

输入:nums = [-1,2,1,-4], target = 1
输出:2
解释:与 target 最接近的和是 2 (-1 + 2 + 1 = 2)。

示例 2:

输入:nums = [0,0,0], target = 1
输出:0
解释:与 target 最接近的和是 0(0 + 0 + 0 = 0)。

提示:

  • 3 <= nums.length <= 1000
  • -1000 <= nums[i] <= 1000
  • -104 <= target <= 104

解题思路

  • 首先根据题意处理边界条件,当数组长度等于 3 时,不需要任何处理,直接返回和即可。
  • 然后,对目标数组进行排序,根据集合有序的特点再结合双指针 lr,与目标 target 进行比较:
    • 当前三元和小于目标值:移动左指针 l 增加。
    • 当前三元和大于目标值:移动右指针 r 减少。
    • 当前三元和等于目标值:由于题目答案唯一,则直接返回当前三元和即可。
  • 当每次移动指针之后,重新计算当前三元和,然后更新当前已经遍历到元素的三元和 min_sum 和最小三元和与目标 target 的差值 min_sum_df
  • 更新时,按照规则:当差值 min_sum_df 最小时,一定有 min_sumtarget 最为接近
  • 最后返回三元和 min_sum 即可。

解题代码

c/c++
#include <vector>
#include <algorithm>class Solution
{
public:int threeSumClosest(std::vector<int> &nums, int target){int sz = nums.size();if (sz == 3)return nums[0] + nums[1] + nums[2];std::sort(nums.begin(), nums.end());int min_sum = nums[0] + nums[1] + nums[2];int min_sum_df = std::abs(target - min_sum);int i = 0;while (i < sz - 2){int l = i + 1, r = sz - 1;while (l < r){int sum = nums[i] + nums[l] + nums[r];int df = std::abs(target - sum);if (df < min_sum_df){min_sum = sum;min_sum_df = df;}if (sum > target)--r;else if (sum < target)++l;elsereturn sum;}++i;}return min_sum;}
};
golang
package mainimport ("math""sort"
)func threeSumClosest(nums []int, target int) int {n := len(nums)if len(nums) == 3 {return nums[0] + nums[1] + nums[2]}sort.Ints(nums)min_sum := nums[0] + nums[1] + nums[2]min_sum_df := math.Abs(float64(target) - float64(min_sum))i := 0for i < n-2 {l, r := i+1, n-1for l < r {sum := nums[i] + nums[l] + nums[r]sum_df := math.Abs(float64(target) - float64(sum))if sum_df < min_sum_df {min_sum = summin_sum_df = sum_df}if sum < target {l++} else if sum > target {r--} else {return sum}}i++}return min_sum
}
lua
local function threeSumClosest(nums, target)local n = #numsif n == 3 thenreturn nums[1] + nums[2] + nums[3]endtable.sort(nums)local min_sum = nums[1] + nums[2] + nums[3];local min_sum_df = math.abs(target - min_sum)local i = 1while i < n - 1 dolocal l, r = i + 1, nwhile l < r dolocal sum = nums[i] + nums[l] + nums[r]local sum_df = math.abs(target - sum)if sum_df < min_sum_df thenmin_sum = summin_sum_df = sum_dfendif sum < target thenl = l + 1elseif sum > target thenr = r - 1elsereturn sumendendi = i + 1endreturn min_sum
end

🌺🌺🌺撒花!

如果本文对你有帮助,就点关注或者留个👍
如果您有任何技术问题或者需要更多其他的内容,请随时向我提问。

在这里插入图片描述


http://www.ppmy.cn/ops/165470.html

相关文章

Python----数据可视化(Seaborn三:绘图二)

一、小提琴图 提琴图的作用与箱形须线图类似。它显示了 数据点按一个&#xff08;或多个&#xff09;变量分组后的分布情况。 与箱图不同的是&#xff0c;每一个小提琴图都是通过对基础分布的核密度估计来绘制的。 方法 violinplot方法 绘制单图小提琴 catplot方法 绘制多图小…

DeepLabv3+改进8:在主干网络中添加SIM注意力机制|助力涨点

🔥【DeepLabv3+改进专栏!探索语义分割新高度】 🌟 你是否在为图像分割的精度与效率发愁? 📢 本专栏重磅推出: ✅ 独家改进策略:融合注意力机制、轻量化设计与多尺度优化 ✅ 即插即用模块:ASPP+升级、解码器 PS:订阅专栏提供完整代码 论文简介 在本文中,我们提出了…

SpringMVC (一)基础

目录 SpringMVC 一 简单使用 1 新建模块选择指定参数 2 创建实现类 3 将项目启动 4 运行结果&#xff1a;在浏览器当中响应执行 二 RequestMapping 三 请求限定 SpringMVC SpringMVC是Spring的web模块&#xff0c;用来开发Web应用&#xff0c;SpringMVC应用最终作为B/…

【git】补丁文件

项目中总有一些本地修改是既不能上传到远程分支又不能直接加入到.gitignore文件中的。 固然可以使用stash但它毕竟只是一种临时保存更改的机制&#xff0c;更适用于本地开发过程中需要频繁切换任务的场景。 如果想要共享代码更改&#xff0c;那还是补丁文件更合适一些。git d…

【C++指南】一文总结C++类和对象【下】

&#x1f31f; 各位看官好&#xff0c;我是egoist2023&#xff01; &#x1f30d; 种一棵树最好是十年前&#xff0c;其次是现在&#xff01; &#x1f680; 今天来学习C类和对象的语法知识。 &#x1f44d; 如果觉得这篇文章有帮助&#xff0c;欢迎您一键三连&#xff0c;分享…

Spring Boot 项目开发流程全解析

目录 引言 一、开发环境准备 二、创建项目 三、项目结构 四、开发业务逻辑 1.创建实体类&#xff1a; 2.创建数据访问层&#xff08;DAO&#xff09;&#xff1a; 3.创建服务层&#xff08;Service&#xff09;&#xff1a; 4.创建控制器层&#xff08;Controller&…

volatile 在 JVM 层面的实现机制

一、JVM 内存模型&#xff08;JMM&#xff09;与 volatile 的语义 Java 内存模型&#xff08;JMM&#xff09;定义了多线程环境下变量的访问规则&#xff0c;而 volatile 关键字通过以下两种语义实现线程安全&#xff1a; 可见性&#xff1a;对 volatile 变量的写操作会立即刷…

车载以太网测试-8【网络层】-IP协议路由协议

目录 1 摘要2 车载以太网网络层介绍2.1 IP协议&#xff08;Internet Protocol&#xff09;2.1.1 IP帧结构2.1.2 IP地址 2 路由协议2.1 静态路由2.2 动态路由 3 总结 1 摘要 车载以太网&#xff08;Automotive Ethernet&#xff09;是一种专门为汽车应用设计的以太网技术&#…