博客
关于我
16 最接近的三数之和(排序、双指针)
阅读量:361 次
发布时间:2019-03-04

本文共 1947 字,大约阅读时间需要 6 分钟。

为了找到数组中三个整数,使其和与目标值最接近,我们可以采用以下步骤:

  • 排序数组:首先对数组进行排序,这有助于使用双指针技巧高效地找到最接近的和。
  • 检查边界情况:如果目标值小于或等于前三个元素的和,或者大于或等于后三个元素的和,可以直接返回对应的和,因为这两个和是可能的最接近值。
  • 初始化变量:设置一个变量来记录当前找到的最接近和,初始值为最大整数。
  • 使用双指针技巧:从数组的第四个元素开始,设左指针在该位置,右指针在数组末尾。根据当前和与目标值的比较,移动指针以缩小差距。
  • 更新最接近值:每次计算当前和时,检查其与目标值的差距,如果比已记录的最接近值更小,则更新最接近值。
  • 返回结果:在遍历结束后,返回最接近值。
  • 以下是具体的实现代码:

    import java.util.Arrays;class Solution {    public int threeSumClosest(int[] nums, int target) {        Arrays.sort(nums);        int len = nums.length;        int closest = Integer.MAX_VALUE;        // 检查前三个和后三个的和        int firstSum = nums[0] + nums[1] + nums[2];        if (target <= firstSum) {            return firstSum;        }        int lastSum = nums[len - 3] + nums[len - 2] + nums[len - 1];        if (target >= lastSum) {            return lastSum;        }        // 遍历数组,使用双指针技巧        for (int a = 0; a <= len - 3; a++) {            // 跳过重复的元素            if (a > 0 && nums[a] == nums[a - 1]) {                continue;            }            int b = a + 1;            int c = len - 1;            while (b < c) {                int currentSum = nums[a] + nums[b] + nums[c];                if (currentSum == target) {                    return target;                }                int diffCurrent = Math.abs(target - currentSum);                int diffClosest = Math.abs(target - closest);                if (diffCurrent < diffClosest) {                    closest = currentSum;                } else if (diffCurrent == diffClosest) {                    // 保持和为正数的顺序,避免不必要的重复                    if (currentSum > closest) {                        closest = currentSum;                    }                }                // 根据当前和与目标的比较,移动指针                if (currentSum < target) {                    b++;                } else {                    c--;                }            }        }        return closest;    }}

    这个代码首先对数组进行排序,然后使用双指针技巧来找到三个数的和与目标值最接近的情况。通过这种方法,我们能够高效地解决问题,避免了暴力枚举所有可能的三元组,显著提高了性能。

    转载地址:http://xjgr.baihongyu.com/

    你可能感兴趣的文章
    Mysql 整形列的字节与存储范围
    查看>>
    mysql 断电数据损坏,无法启动
    查看>>
    MySQL 日期时间类型的选择
    查看>>
    Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
    查看>>
    MySQL 是如何加锁的?
    查看>>
    MySQL 是怎样运行的 - InnoDB数据页结构
    查看>>
    mysql 更新子表_mysql 在update中实现子查询的方式
    查看>>
    MySQL 有什么优点?
    查看>>
    mysql 权限整理记录
    查看>>
    mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
    查看>>
    MYSQL 查看最大连接数和修改最大连接数
    查看>>
    MySQL 查看有哪些表
    查看>>
    mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
    查看>>
    MySql 查询以逗号分隔的字符串的方法(正则)
    查看>>
    MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
    查看>>
    mysql 查询数据库所有表的字段信息
    查看>>
    【Java基础】什么是面向对象?
    查看>>
    mysql 查询,正数降序排序,负数升序排序
    查看>>
    MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
    查看>>
    mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
    查看>>