L1-025 正整数A+B (15分) C++

题目描述

题的目标很简单,就是求两个正整数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]之间,如果不满足则输出"?",其次需要注意B中可能出现空格,比如样例123 3 4字符串A为"123",B为"3 4",所以为了能够存储B的全部内容,使用getline(cin,b)。
输出的时候按照每一项的判断进行

C++ 代码

#include<bits/stdc++.h>
using namespace std;
int n1,n2;
bool f1=true,f2=true,f3=true,f4=true;
int main()
{
    
    
	string a,b;
	cin>>a;
	getchar();  //抵消空格
	getline(cin,b); //b中可能包含空格,所以用getline进行输入
	for(int i=0;i<a.size();i++)
	{
    
    
		if(a[i]>='0' && a[i]<='9')
		{
    
    
			n1=10*n1+(a[i]-'0');
		}
		else{
    
    
			f1=false;   
			break;
		}
	}
	for(int i=0;i<b.size();i++)
	{
    
    
		if(b[i]>='0' && b[i]<='9')
		{
    
    
			n2=10*n2+(b[i]-'0');
		}
		else{
    
    
			f2=false;
			break;
		}
	}
	if(n1>1000 || n1<1) f3=false;
	if(n2>1000 || n2<1) f4=false;
	if(f1 && f3) cout<<n1;
	else cout<<"?";
	cout<<" + ";
	if(f2 && f4) cout<<n2;
	else cout<<"?";
	cout<<" = ";
	if(f1 && f2 && f3 && f4) cout<<n1+n2;
	else cout<<"?";
	return 0;
} 

猜你喜欢

转载自blog.csdn.net/Jay_fearless/article/details/109323375
今日推荐