登录
首页 >  文章 >  java教程

Java如何判断三数中有两数和为20

时间:2026-05-11 15:01:16 421浏览 收藏

本文深入剖析了Java中判断三个整数是否存在两数之和为20的经典问题,直击原代码中数组容量设为2却强行处理3个输入、输入次数不足、双指针范围错位等致命缺陷,并指出负数场景下的错误根源并非算法本身而是数据缺失;文章不仅提供简洁高效的O(1)枚举解法(直接校验a+b、a+c、b+c三组组合),还严谨给出了可运行的双指针教学版,强调数组长度必须为3、排序前提不可省略、指针边界必须精准——帮你彻底避开“元素个数≠数组长度”的常见陷阱,写出逻辑清晰、鲁棒性强、零边界风险的正确代码。

Java中检查三数中是否存在两数之和等于20的正确实现

本文详解如何在Java中判断三个输入整数中是否存在任意两个数之和恰好为20,重点修复原代码中数组长度误设、输入数量不足及双指针算法适配性等关键错误。

本文详解如何在Java中判断三个输入整数中是否存在任意两个数之和恰好为20,重点修复原代码中数组长度误设、输入数量不足及双指针算法适配性等关键错误。

原问题要求:读入三个整数 a、b、c,判断其中是否存在一对数(共三种组合:a+b、a+c、b+c)其和恰好等于20,输出 true 或 false。但提供的代码存在多个根本性缺陷,导致对负数(如输入 -5 25 10)或任意三数场景均无法正确运行。

主要错误分析

  1. 数组容量错误:声明 int[] arrayOfNumbers = new int[2]; —— 只能存2个数,但题目明确要求读取三个数(a, b, c),导致第三个输入被忽略或引发 InputMismatchException。
  2. arr_size 传参错误:调用 hasArrayTwoCandidates(arrayOfNumbers, size, howMuch) 时传入 size = 2,但实际应为 3;更严重的是,该方法内部使用 Arrays.sort(A) 对传入的引用数组排序,而数组长度为2,却试图处理3个输入,逻辑完全错位。
  3. 算法适用前提不满足:双指针法 hasArrayTwoCandidates 要求输入数组完整包含所有待查数字且长度准确。当前代码既未读满3个数,又用2元数组承载3数逻辑,导致排序与双指针范围失效——尤其当负数出现时(如 -5 + 25 = 20),因数据缺失或越界,必然返回错误结果。

正确实现方案(推荐简洁鲁棒版)

无需排序与双指针,直接枚举全部三组两两组合,代码清晰、高效(O(1))、天然支持负数、零和大数:

import java.util.Scanner;

class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        // 准确读取三个整数
        int a = scanner.nextInt();
        int b = scanner.nextInt();
        int c = scanner.nextInt();

        // 检查所有可能的两数组合
        boolean found = (a + b == 20) || (a + c == 20) || (b + c == 20);
        System.out.println(found);
    }
}

优势说明

  • 完全覆盖题意:显式处理 a+b、a+c、b+c 三种组合;
  • 负数无忧:-8 + 28 == 20、-10 + 30 == 20 等均正确判定;
  • 无边界风险:不依赖数组索引计算,避免 ArrayIndexOutOfBoundsException;
  • 性能最优:仅3次加法+2次逻辑或,常数时间完成。

若坚持使用双指针法(教学拓展)

需严格保证:① 数组长度为3;② 输入完整;③ 排序后双指针遍历整个有效范围:

import java.util.Arrays;
import java.util.Scanner;

class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int[] nums = new int[3]; // ✅ 容量为3
        for (int i = 0; i < 3; i++) { // ✅ 循环3次
            nums[i] = scanner.nextInt();
        }

        System.out.println(hasPairWithSum(nums, 20));
    }

    static boolean hasPairWithSum(int[] arr, int target) {
        Arrays.sort(arr); // 排序是双指针前提
        int left = 0, right = arr.length - 1; // ✅ right = 2(索引合法)
        while (left < right) {
            int sum = arr[left] + arr[right];
            if (sum == target) return true;
            else if (sum < target) left++;
            else right--;
        }
        return false;
    }
}

⚠️ 注意事项

  • 双指针法在此题中属于“过度设计”,但可帮助理解算法思想;
  • 必须确保 arr.length == 3 且 right 初始化为 arr.length - 1,否则负数场景下因数据不全或指针越界导致漏判。

总结

解决此类“多数中找两数和”问题,优先选择直接组合判断——逻辑直白、不易出错、性能卓越。务必根据题目要求精确分配数组大小、控制输入次数,并警惕将“元素个数”与“数组长度”混淆的常见陷阱。当输入含负数时,更需验证数据完整性,而非归咎于算法本身。

终于介绍完啦!小伙伴们,这篇关于《Java如何判断三数中有两数和为20》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>