Leecode刷题之路第16天之最接近的三数之和

Scroll Down

题目出处

16-最接近的三数之和-题目出处

题目描述

16-最接近的三数之和-题目描述

个人解法

思路:

todo

代码示例:(Java)

todo

复杂度分析

todo

官方解法

16-最接近的三数之和-官方解法

方法1:排序+双指针

思路:

16-最接近的三数之和-排序双指针1
16-最接近的三数之和-排序双指针2

代码示例:(Java)

public int threeSumClosest(int[] nums, int target) {
        Arrays.sort(nums);
        int n = nums.length;
        int best = 10000000;

        // 枚举 a
        for (int i = 0; i < n; ++i) {
            // 保证和上一次枚举的元素不相等
            if (i > 0 && nums[i] == nums[i - 1]) {
                continue;
            }
            // 使用双指针枚举 b 和 c
            int j = i + 1, k = n - 1;
            while (j < k) {
                int sum = nums[i] + nums[j] + nums[k];
                // 如果和为 target 直接返回答案
                if (sum == target) {
                    return target;
                }
                // 根据差值的绝对值来更新答案
                if (Math.abs(sum - target) < Math.abs(best - target)) {
                    best = sum;
                }
                if (sum > target) {
                    // 如果和大于 target,移动 c 对应的指针
                    int k0 = k - 1;
                    // 移动到下一个不相等的元素
                    while (j < k0 && nums[k0] == nums[k]) {
                        --k0;
                    }
                    k = k0;
                } else {
                    // 如果和小于 target,移动 b 对应的指针
                    int j0 = j + 1;
                    // 移动到下一个不相等的元素
                    while (j0 < k && nums[j0] == nums[j]) {
                        ++j0;
                    }
                    j = j0;
                }
            }
        }
        return best;
    }

复杂度分析

16-最接近的三数之和-复杂度分析

考察知识点

收获

1.对数

16-最接近的三数之和-对数术语

Gitee源码位置

16-最接近的三数之和-源码

同名文章,已同步发表于CSDN,个人网站,公众号