7-1 正整数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:
? + ? = ?

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.StringTokenizer;

//** Class for buffered reading int and double values *//*
class Reader {
	static BufferedReader reader;
	static StringTokenizer tokenizer;

	// ** call this method to initialize reader for InputStream *//*
	static void init(InputStream input) {
		reader = new BufferedReader(new InputStreamReader(input));
		tokenizer = new StringTokenizer("");
	}

	// ** get next word *//*
	static String next() throws IOException {
		while (!tokenizer.hasMoreTokens()) {
			// TODO add check for eof if necessary
			tokenizer = new StringTokenizer(reader.readLine());
		}
		return tokenizer.nextToken();
	}
	static boolean hasNext()throws IOException {
		return tokenizer.hasMoreTokens();
	}
	static String nextLine() throws IOException{
		return reader.readLine();
	}
	static char nextChar() throws IOException{
		return next().charAt(0);
	}
	static int nextInt() throws IOException {
		return Integer.parseInt(next());
	}

	static float nextFloat() throws IOException {
		return Float.parseFloat(next());
	}
}
public class Main {
	public static void main(String[] args) throws IOException {
		Reader.init(System.in);
		String a = Reader.next();
		String b = "";
		
		boolean flag1 = false;	
        boolean flag2 = false;
        
		while(Reader.hasNext()) {
			b+=Reader.next();
		}
		if (a.matches("\\d+")) {
			if (Integer.parseInt(a)>=1&&Integer.parseInt(a)<=1000) {
				flag1 = true;
			}
		}
		if (b.matches("\\d+")) {
			if (Integer.parseInt(b)>=1&&Integer.parseInt(b)<=1000) {
				flag2 = true;
			}
		}
		if (flag1 && flag2)
            System.out.printf("%s + %s = %d", a, b, Integer.parseInt(a) + Integer.parseInt(b));
        else if (flag1 && !flag2)
            System.out.printf("%s + ? = ?", a);
        else if (!flag1 && flag2)
            System.out.printf("? + %s = ?", b);
        else
            System.out.printf("? + ? = ?");
	}
	

}



发布了45 篇原创文章 · 获赞 8 · 访问量 1785

猜你喜欢

转载自blog.csdn.net/weixin_43888039/article/details/104007506
今日推荐