2021/3/19算法题打卡-正整数A加B
正整数A加B
题目
题的目标很简单,就是求两个正整数A和B的和,其中A和B都在区间[1,1000]。稍微有点麻烦的是,输入并不保证是两个正整数。
输入格式:
输入在一行给出A和B,其间以空格分开。问题是A和B不一定是满足要求的正整数,有时候可能是超出范围的数字、负数、带小数点的实数、甚至是一堆乱码。注意:我们把输入中出现的第1个空格认为是A和B的分隔。题目保证至少存在一个空格,并且B不是一个空字符串。
输出格式:
如果输入的确是两个正整数,则按格式A + B = 和输出。如果某个输入不合要求,则在相应位置输出?,显然此时和也是?。输入样例1:
123 456
输出样例1:
123 + 456 = 579
输入样例2:
- 18
输出样例2:
? + 18 = ?
输入样例3:
-100 blabla bla...33
输出样例3:
? + ? = ?
分析
本题不难,但是比较麻烦,需要小心。
最难的部分就是判断是否为整数
我采用的是正则表达式来判断
代码
package com.天梯赛练习题;
import java.util.Scanner;
import java.util.regex.Pattern;
/**
* @auther thk
* @date 2021/3/19 - 22:57
*/
public class L1_025正整数A加B {
public static boolean isInteger(String str) {
Pattern pattern = Pattern.compile("^[\\+]?[\\d]*$");
return pattern.matcher(str).matches();
}
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
String s[] = scanner.nextLine().split(" ");
StringBuilder stringBuilder = new StringBuilder();
StringBuilder str = new StringBuilder();
for(int i=1;i<s.length;i++){
stringBuilder.append(s[i]);
}
boolean int0 = isInteger(s[0]);
int A=0;
int flag=0;
if(int0) {
A = Integer.parseInt(s[0]);
if(A>=1 && A<=1000)
str.append(A+" ");
else {
str.append("? ");
flag = 1;
}
}else{
str.append("? ");
flag=1;
}
str.append("+ ");
boolean int1 = isInteger(stringBuilder.toString());
int B=0;
int C=0;
if(int1) {
B = Integer.parseInt(stringBuilder.toString());
if(B>=1 && B<=1000) {
str.append(B + " ");
C = A + B;
}else{
str.append("? ");
flag=1;
}
}else{
str.append("? ");
flag=1;
}
str.append("= ");
if(flag==0)
str.append(C);
else
str.append("?");
System.out.println(str.toString());
}
}