java L1-025 正整数A+B (15分)
题的目标很简单,就是求两个正整数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:
? + ? = ?
解题思路:
用java还是很简单的,这道题拿过来一看直接找空格,以空格分为两个字符串,然后匹配一下哪个字符串是正整数,我上来写出来了,然后一直有样例过不去,最后发现是[1,1000],直接刨除1-1000之外就好。
import java.util.Scanner;
public class AB {
public static void main(String[] args) {
Scanner cin = new Scanner(System.in);
String str = cin.nextLine();
Add(str);
}
public static void Add(String str){
int n= str.indexOf(" "); //标记出两数分割处
String str1 = str.substring(0,n); //切出前半段
String str2 = str.substring(n+1); //切出后半段
boolean s1 = str1.matches("[0-9]+"); //匹配一下前半段都是数字
boolean s2 = str2.matches("[1-9][0-9]+"); //匹配一下后半段但是把0刨除去
if(s1==true&&s2==true){ //正常的两个数相加就好
int a = Integer.parseInt(str1);
int b = Integer.parseInt(str2);
if(a>1000){ //这里是把1000以外取出
System.out.println("?"+" "+"+"+" "+b+" "+"="+" "+"?");
}
else
System.out.println(a+" "+"+"+" "+b+" "+"="+" "+(a+b));
}
if(s1==true&&s2==false){
int a = Integer.parseInt(str1);
System.out.println(a+" "+"+"+" "+"?"+" "+"="+" "+"?");
}
if(s1==false&&s2==true){
int b = Integer.parseInt(str2);
System.out.println("?"+" "+"+"+" "+b+" "+"="+" "+"?");
}
if(s1==false&&s2==false)
System.out.println("?"+" "+"+"+" "+"?"+" "+"="+" "+"?");
}
}