0
点赞
收藏
分享

微信扫一扫

L1-025 正整数A+B (15 分) 有思路,有解答,C++解法(个别测试样例不通过)

转角一扇门 2022-03-26 阅读 106

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:
? + ? = ?

#include<iostream>
#include<stack> 
#include<sstream>
using namespace std;

int main(){
	
	string a;
	string b;
	cin>>a;
	cin>>b;
	int flag_a=0;
	int flag_b=0;
	for(int i=0;i<a.length();i++){
		if(a.at(i)>='0'&&a.at(i)<='9'){
			if(i==a.length()-1){
				flag_a=1;
				stringstream rr;
				int k;
				rr<<a;
				rr>>k;
				if(k<=1000&&k>=1){
					
				}else {
					flag_a=0;
					cout<<"? ";
					break;
				}
			}
		}else {
		cout<<"? ";
		break;
			}
		
	}
	
	if(flag_a==1){
		cout<<a<<" ";
	}
	cout<<"+ ";

	for(int j=0;j<b.length();j++){
		
			if(b.at(j)>='0'&&b.at(j)<='9'){
			if(j==b.length()-1){
				flag_b=1;
				stringstream rr;
				int k;
				rr<<b;
				rr>>k;
				if(k<=1000&&k>=1){
					
				}else {
					flag_b=0;
					cout<<"? ";
					break;
				}
			}
		}else {
		cout<<"? ";
		break;
			}
		
	}
	if(flag_b==1){
		cout<<b<<" = ";
	}else cout<<" = ";
	if(flag_a==1&&flag_b==1){
		int r;
		int t;
		
		stringstream ss;
		stringstream rr;
		ss<<a;
		ss>>r;
//		cout<<"r"<<r<<endl;
		rr<<b;
		rr>>t;
//		cout<<"t"<<t<<endl;
		cout<<r+t;
		
		
	}else cout<<"?";
}
举报

相关推荐

0 条评论