侧边栏壁纸
博主头像
GabrielxD

列車は必ず次の駅へ。では舞台は?私たちは?

  • 累计撰写 675 篇文章
  • 累计创建 128 个标签
  • 累计收到 29 条评论

目 录CONTENT

文章目录

【排序, 双指针】最接近的三数之和

GabrielxD
2022-10-21 / 0 评论 / 0 点赞 / 438 阅读 / 309 字
温馨提示:
本文最后更新于 2022-11-04,若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益,请联系我们删除。

题目

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
  • -10^4 <= target <= 10^4

解题

方法一:排序 双指针

思路

【排序, 双指针】三数之和几乎相同,唯一不同的点是这次只需要找到最接近 target 的和,所以维护一个 closest 每次移动指针后更新即可。

代码

class Solution {
    public int threeSumClosest(int[] nums, int target) {
        int n = nums.length;
        Arrays.sort(nums);
        int closest = nums[0] + nums[1] + nums[2];
        for (int i = 0; i < n - 2; ++i) {
            int a = nums[i];
            int left = i + 1, right = n - 1;
            while (left < right) {
                int curr = a + nums[left] + nums[right];
                if (Math.abs(curr - target) < Math.abs(closest - target))
                    closest = curr;
                if (curr > target) --right;
                else if (curr < target) ++left;
                else return target; 
            }
        }
        return closest;
    }
}
0

评论区