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,重点修复原代码中数组长度误设、输入数量不足及双指针算法适配性等关键错误。
原问题要求:读入三个整数 a、b、c,判断其中是否存在一对数(共三种组合:a+b、a+c、b+c)其和恰好等于20,输出 true 或 false。但提供的代码存在多个根本性缺陷,导致对负数(如输入 -5 25 10)或任意三数场景均无法正确运行。
主要错误分析
- 数组容量错误:声明 int[] arrayOfNumbers = new int[2]; —— 只能存2个数,但题目明确要求读取三个数(a, b, c),导致第三个输入被忽略或引发 InputMismatchException。
- arr_size 传参错误:调用 hasArrayTwoCandidates(arrayOfNumbers, size, howMuch) 时传入 size = 2,但实际应为 3;更严重的是,该方法内部使用 Arrays.sort(A) 对传入的引用数组排序,而数组长度为2,却试图处理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学习网公众号也会发布文章相关知识,快来关注吧!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
480 收藏
-
421 收藏
-
188 收藏
-
466 收藏
-
237 收藏
-
457 收藏
-
483 收藏
-
182 收藏
-
337 收藏
-
235 收藏
-
410 收藏
-
400 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习