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

本文共 1995 字,大约阅读时间需要 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/

    你可能感兴趣的文章
    Nginx 学习总结(16)—— 动静分离、压缩、缓存、黑白名单、性能等内容温习
    查看>>
    Nginx 学习总结(17)—— 8 个免费开源 Nginx 管理系统,轻松管理 Nginx 站点配置
    查看>>
    Nginx 学习(一):Nginx 下载和启动
    查看>>
    nginx 常用指令配置总结
    查看>>
    Nginx 常用配置清单
    查看>>
    nginx 常用配置记录
    查看>>
    nginx 开启ssl模块 [emerg] the “ssl“ parameter requires ngx_http_ssl_module in /usr/local/nginx
    查看>>
    Nginx 我们必须知道的那些事
    查看>>
    Nginx 的 proxy_pass 使用简介
    查看>>
    Nginx 的配置文件中的 keepalive 介绍
    查看>>
    Nginx 结合 consul 实现动态负载均衡
    查看>>
    Nginx 负载均衡与权重配置解析
    查看>>
    Nginx 负载均衡详解
    查看>>
    nginx 配置 单页面应用的解决方案
    查看>>
    nginx 配置https(一)—— 自签名证书
    查看>>
    nginx 配置~~~本身就是一个静态资源的服务器
    查看>>
    Nginx 配置清单(一篇够用)
    查看>>
    Nginx 配置解析:从基础到高级应用指南
    查看>>
    nginx+php的搭建
    查看>>
    nginx+tomcat+memcached
    查看>>