LeetCode第16题最接近的三数之和

继续打卡算法题,今天学习的是LeetCode的第16题最接近的三数之和,这道题目是道中等题。算法题的一些解题思路和技巧真的非常巧妙,每天看一看算法题和解题思路,我相信对我们的编码思维和编码能力有一些帮助。

分析一波题目

这个题目和15题极其相似,其实解决的办法是一样的套路,通过双指针法减少循环次数,降低时间复杂度。

编码实现

java 复制代码
	class Solution {
    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;

    }
}

总结

和15题目解题一样,始终要记得双指针可以减少循环次数。

相关推荐
元亓亓亓1 分钟前
LeetCode热题100--560.和为K的子数组(前缀和)--中等
算法·leetcode·职场和发展
前端付豪2 分钟前
3、Node.js异步编程彻底吃透
前端·后端·node.js
老胖闲聊4 分钟前
Flask 请求数据获取方法详解
后端·python·flask
Phoebe鑫7 分钟前
数据结构每日一题day12(链表)★★★★★
数据结构·算法·链表
舒一笑7 分钟前
一文简单记录打通K8s+Kibana流程如何启动(Windows下的Docker版本)
后端·elasticsearch·kibana
亦黑迷失8 分钟前
轻量级 Express 服务器:用 Pug 模板引擎实现动态参数传递
前端·javascript·后端
慧一居士17 分钟前
Kafka批量消费部分处理成功时的手动提交方案
分布式·后端·kafka
香蕉可乐荷包蛋39 分钟前
Python面试问题
开发语言·python·面试
Vacant Seat44 分钟前
贪心算法-跳跃游戏II
算法·游戏·贪心算法
命中的缘分1 小时前
SpringCloud原理和机制
后端·spring·spring cloud