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

LeetCode-16.最接近的三数之和 C++实现

一 题目描述

给你一个长度为 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)。

二.问题思路

解决最接近的三数之和问题,核心思路是排序 + 双指针法,具体步骤如下

1.排序数组

  • 目的:将数组升序排列,便于后续双指针操作。

  • 作用:排序后,可以通过固定一个数,利用双指针在剩余区间内高效寻找另外两个数

2.初始化最近值

  • 初始化 closest_sum 为前三个元素的和,min_distance 为当前和与目标值的距离绝对值。

  • 意义:为后续比较提供初始基准值。

3.遍历固定第一个数

  • 外层循环:遍历数组,固定第一个数 nums[i]

    • 跳过重复值:若 i > 0 且 nums[i] == nums[i-1],跳过当前 i,避免重复计算相同三元组(优化点)。

    • 双指针初始化left = i + 1right = n - 1,在区间 [i+1, n-1] 内寻找另外两个数。

 4.双指针寻找目标值

  • 内层循环:当 left < right 时:

    1. 计算当前三数之和 sum = nums[i] + nums[left] + nums[right]

    2. 更新最近值:若当前和与目标的距离 distance 小于 min_distance,则更新 closest_sum 和 min_distance

    3. 调整指针

      • 若 sum < target:左指针右移(增大和)。

      • 若 sum > target:右指针左移(减小和)。

      • 若 sum == target:直接返回 sum(此时距离为 0,已最优)。

5.终止条件与返回
  • 循环结束:遍历所有可能的 i 后,返回 closest_sum

  • 提前终止:若某次 sum == target,直接返回结果,无需继续计算。

 代码实现

class Solution {
public:int threeSumClosest(vector<int>& nums, int target) {sort(nums.begin(), nums.end());int n = nums.size();int closest_sum= nums[0] + nums[1] + nums[2];int min_distance = abs(target - closest_sum);for (int i = 0;i < n - 2;i++){if (i > 0 && nums[i] == nums[i - 1]) continue;int left = i + 1, right = n - 1;while (left < right){int sum= nums[i] + nums[left] + nums[right];int distance = abs(target - sum);if (distance < min_distance){min_distance = distance;closest_sum = sum;}if (sum < target) {left++; // 需要更大的数,左指针右移}else if (sum > target) {right--; // 需要更小的数,右指针左移}else {return sum; // 和等于目标值,直接返回}}}return closest_sum;}
};


文章转载自:

http://7LXrKNKn.sxjmz.cn
http://v89DDNuE.sxjmz.cn
http://D20N5mDe.sxjmz.cn
http://rkIGTUpu.sxjmz.cn
http://6gT9QxgI.sxjmz.cn
http://5i6ABPrs.sxjmz.cn
http://yN5wi4q4.sxjmz.cn
http://hwZJjAHr.sxjmz.cn
http://sgYn69dB.sxjmz.cn
http://MLECTm5x.sxjmz.cn
http://qAFwDPni.sxjmz.cn
http://LD80zR2F.sxjmz.cn
http://JwVBxmq7.sxjmz.cn
http://j9wDgBUY.sxjmz.cn
http://c4XRunIi.sxjmz.cn
http://1hJCt00I.sxjmz.cn
http://95caAbP6.sxjmz.cn
http://OAkJvdDm.sxjmz.cn
http://upTmeTLa.sxjmz.cn
http://FsjZmG1g.sxjmz.cn
http://EhvErOq5.sxjmz.cn
http://1asBvsgo.sxjmz.cn
http://AqbmiUs1.sxjmz.cn
http://Xm4LtKuV.sxjmz.cn
http://WAhkF0Lg.sxjmz.cn
http://iaQVfnHz.sxjmz.cn
http://qLGOuoOh.sxjmz.cn
http://qtVDum3s.sxjmz.cn
http://c8b68Lv3.sxjmz.cn
http://1nvVdUQD.sxjmz.cn
http://www.dtcms.com/a/137183.html

相关文章:

  • 保姆级教程:RK3588部署yolo目标检测模型
  • HarmontOS-ArkUI V2状态 !!语法糖 双向绑定
  • AI(人工智能)学习中的主要分类及其详细说明
  • Python异常处理全面指南
  • Spring Batch 专题系列(七):Spring Batch 与数据库集成
  • Apipost,前端后端测试都在用的接口设计调试工具
  • python——循环语句
  • 如何选择合适的数据类型以节省存储空间和提升查询效率?
  • Android 应用添加Tile到SystemUI QuickSettings
  • 微信小程序边框容器带三角指向
  • 力扣热题100——普通数组(不普通)
  • 广告ROI提升警报:亚马逊新功能如何重构卖家流量漏斗
  • SpringAI版本更新:向量数据库不可用的解决方案!
  • ​​eBay东南亚爆单密码:72小时交付计划如何重构厦门仓+东南亚供应链?​
  • SpringAI+DeepSeek大模型应用开发——1 AI概述
  • 云游戏盒子的硬件设计与趋势分析
  • (3)VTK C++开发示例 --- 旋转的锥体
  • 什么是高防服务器
  • 【正点原子STM32MP257连载】第四章 ATK-DLMP257B功能测试——USB WIFI测试 #WIFI蓝牙二合一 #RTL8733BU
  • STM32F103C8T6 单片机入门基础知识及点亮第一个 LED 灯
  • 从单模态到多模态:五大模型架构演进与技术介绍
  • ping, tracert, tracepath, traceroute, ssh, telnet, tcping详细解释
  • 如何知道raid 有问题了
  • 单个霍尔传感器时,也存在上升沿和下降沿,为什么双边沿计数需要两个霍尔传感器呢?
  • 基于MCAL的S32K312 delay功能实现
  • Chatbox上使用本地和在线DeepSeek以及硅基流动DeepSeekI的对比感受
  • 如何利用GM DC Monitor快速监控一台网络类设备
  • OOP丨《Java编程思想》阅读笔记Chapter 5 : 初始化与清理
  • python爬虫降低IP封禁,python爬虫除了使用代理IP和降低请求频率,还有哪些方法可以应对IP封禁?
  • Cursor入门教程-JetBrains过度向