leetCode刷题 & 16. 最接近的三数之和

题目:

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

提示:

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

1. 思路

这道题与三数之和问题类似,只是要求返回与目标值最接近的三个数的和。可以使用双指针法来解决这个问题。首先对数组进行排序,然后固定一个数,再使用双指针来搜索其余两个数,计算它们的和与目标值的差的绝对值,不断更新最小的差值。最后返回最接近的三个数的和。

2. 解题方法

  1. 对数组进行排序,时间复杂度为 O(nlogn)。
  2. 初始化一个变量 closestSum 用于记录最接近目标值的三个数的和。初始值设为数组的前三个数的和。
  3. 遍历数组,对每一个数固定为 nums[i]
    • 初始化双指针 left = i + 1right = n - 1,分别指向数组的左右两端。
    • left < right 的条件下,计算当前三个数的和 sum = nums[i] + nums[left] + nums[right]
    • 如果 sumtarget 的差的绝对值小于 closestSumtarget 差的绝对值,则更新 closestSumsum
    • 如果 sum 大于 target,则将 right 左移一位;如果 sum 小于 target,则将 left 右移一位;如果 sum 等于 target,则直接返回 sum
  4. 返回 closestSum

3. 复杂度

  • 时间复杂度:排序数组的时间复杂度为 O(nlogn),固定一个数后使用双指针遍历数组的时间复杂度为 O(n^2),总体时间复杂度为 O(n^2 + nlogn) = O(n^2)。
  • 空间复杂度:O(1)。

4. Code

java 复制代码
import java.util.Arrays;

class Solution {
    public int threeSumClosest(int[] nums, int target) {
        Arrays.sort(nums); // 对数组进行排序
        int closestSum = nums[0] + nums[1] + nums[2]; // 初始化最接近目标值的三个数的和为数组的前三个数的和
        
        for (int i = 0; i < nums.length; i++) {
            int left = i + 1;
            int right = nums.length - 1;
            
            while (left < right) {
                int sum = nums[i] + nums[left] + nums[right]; // 计算当前三个数的和
                if (Math.abs(sum - target) < Math.abs(closestSum - target)) { // 更新最接近目标值的三个数的和
                    closestSum = sum;
                }
                
                if (sum > target) {
                    right--; // 如果当前和大于目标值,将右指针左移
                } else if (sum < target) {
                    left++; // 如果当前和小于目标值,将左指针右移
                } else {
                    return sum; // 如果当前和等于目标值,直接返回
                }
            }
        }
        
        return closestSum;
    }
}

欢迎大家后台联系讨论。

(一份比较早的面试宝典,有兴趣的读者姥爷可以私信我领取!!!免费滴)

相关推荐
是小蟹呀^3 分钟前
Java 内部类详解:成员内部类、静态内部类、局部内部类与匿名内部类
java·内部类
We་ct12 分钟前
LeetCode 4. 寻找两个正序数组的中位数:二分优化思路详解
前端·数据结构·算法·leetcode·typescript·二分
于先生吖16 分钟前
国际语言适配拼车系统 JAVA 后端源码 + 同城顺风车功能全解析
java·开发语言
czlczl2002092525 分钟前
KRaft原理
java·zookeeper
仍然.39 分钟前
算法题目---位运算
算法
计算机安禾1 小时前
【数据结构与算法】第10篇:项目实战:学生信息管理系统(线性表版)
开发语言·数据结构·算法·visual studio
q_35488851531 小时前
计算机毕业设计:汽车数据可视化与智能分析平台 Django框架 Scrapy爬虫 可视化 车辆 懂车帝大数据 数据分析 机器学习(建议收藏)✅
算法·信息可视化·django·flask·汽车·课程设计·美食
毕设源码-朱学姐1 小时前
【开题答辩全过程】以 基于SSM的宜佳家具电商平台为例,包含答辩的问题和答案
java
FakeOccupational1 小时前
【电路笔记 通信】IEEE 1588精密时间协议(PTP):数学假设+时间同步链路建模+消除主从偏差算法
笔记·算法
客卿1231 小时前
最小生成树(贪心)--构造回文串(字符串 + 回文判断 + 构造)
java·开发语言·算法