本文主要是介绍L1-025 正整数A+B(Java),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
题的目标很简单,就是求两个正整数A和B的和,其中A和B都在区间[1,1000]。稍微有点麻烦的是,输入并不保证是两个正整数。
输入格式:
输入在一行给出A和B,其间以空格分开。问题是A和B不一定是满足要求的正整数,有时候可能是超出范围的数字、负数、带小数点的实数、甚至是一堆乱码。
注意:我们把输入中出现的第1个空格认为是A和B的分隔。题目保证至少存在一个空格,并且B不是一个空字符串。
输出格式:
如果输入的确是两个正整数,则按格式A + B = 和输出。如果某个输入不合要求,则在相应位置输出?,显然此时和也是?。
输入样例1:
123 456
输出样例1:
123 + 456 = 579
输入样例2:
22. 18
输出样例2:
? + 18 = ?
输入样例3:
-100 blabla bla...33
输出样例3:
? + ? = ?
解题思路
- 题目要求是两个在[1,1000]的正整数的和。但是两个数不一定都是满足要求的正整数。
- 输出格式上需要对某个输入不合要求数字的位置改为?,和也应该是?
- 使用BufferedReader读取一行输入。(防止有运行超时问题)
- 使用空格将输入分割成两个部分(r1和r2)。
- 分别尝试将这两个部分解析为整数(x1和x2)。
- 如果任一部分无法解析为有效的整数或者不在1到1000的范围内,相应的输出部分(s1或s2)被设置为"?"。
- 如果任一输入无效,总和(s3)也被设置为"?"。
- 根据s1、s2和s3的值,输出最终结果。
解题过程中遇到的问题
对于以下两种写法大多数情况是等效的,但是在处理特定输入时表现略有不同
第一种写法
String[] s = in.readLine().split(" ");
String r1 = s[0];
String r2 = s[1];第二种写法
String s = in.readLine();
String r1 = s.substring(0, s.indexOf(' '));
String r2 = s.substring(s.indexOf(' ') + 1);
如果使用第一种写法,会出现一种情况答案错误。
解析使用split(" ")和使用substring以及indexof(' ')的这两种方法
- 使用split(" ")的方法:
-
- 这种方法将字符串按照空格分割成一个字符串数组。如果输入中有多个连续的空格,split方法会将它们视为分隔符之间的空字符串。
- 当输入恰好包含一个空格时,这种方法是有效的。但如果输入中包含多个连续的空格或者在开头/结尾有空格,这种方法可能导致数组包含空字符串或多于两个的元素。
- 示例:对于输入 "123 456"(假设中间有多个空格),split(" ")将返回一个包含多个元素的数组,其中只有第一个和最后一个元素是有意义的数字字符串。
- 使用substring和indexOf(' ')的方法:
-
- 这种方法直接寻找第一个空格的位置,并据此将字符串分割成两部分。它不会被连续的空格所影响。
- 这种方法在输入中恰好有一个空格时效果最佳。如果有多个连续空格,它只会识别第一个空格,因此不会受到额外空格的影响。
- 示例:对于同样的输入 "123 456",使用substring和indexOf(' ')将只会识别第一个空格,并正确地将字符串分割为 "123" 和 "456"。
总的来说,如果输入可能包含多个连续空格或在开头/结尾有空格,使用substring和indexOf(' ')的方法更加可靠,因为它只关注第一个空格并据此分割字符串。相比之下,split(" ")可能会因为额外的空格而产生非预期的行为,尤其是当输入格式不严格时。
情况展示
第一种结果是使用以下代码
String[] s = in.readLine().split(" ");
String r1 = s[0];
String r2 = s[1];
第二种结果是使用以下代码(正确的处理)
String s = in.readLine();
String r1 = s.substring(0, s.indexOf(' '));
String r2 = s.substring(s.indexOf(' ') + 1);
代码
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;public class Main {public static void main(String[] args) throws IOException {BufferedReader in = new BufferedReader(new InputStreamReader(System.in));String s = in.readLine();String r1 = s.substring(0, s.indexOf(' '));String r2 = s.substring(s.indexOf(' ') + 1);String s1 = "", s2 = "", s3 = "";int n1 = 0, n2 = 0;try {n1 = Integer.parseInt(r1);if (n1 < 1 || n1 > 1000) {s1 = "?";s3 = "?";}} catch (NumberFormatException e) {s1 = "?";s3 = "?";}try {n2 = Integer.parseInt(r2);if (n2 < 1 || n2 > 1000) {s2 = "?";s3 = "?";}} catch (NumberFormatException e) {s2 = "?";s3 = "?";}System.out.print(s1.equals("") ? n1 + " + " : s1 + " + ");System.out.print(s2.equals("") ? n2 + " = " : s2 + " = ");System.out.println(s3.equals("") ? (n1 + n2) : s3);}
}
这篇关于L1-025 正整数A+B(Java)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!