2016年团体程序设计天梯赛-决赛 L1-1. 正整数A+B(15)

时间:2023-03-09 17:54:06
2016年团体程序设计天梯赛-决赛 L1-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:

? + ? = ?

记得只有在[1,1000]范围里的数字才有效哦
 #include<stdio.h>
#include<iostream>
#include<math.h>
#include<string.h>
#include<limits.h>
#include<algorithm>
#include<queue>
using namespace std; int main()
{
char a[],b[];
cin>>a;
scanf(" ");
gets(b);
bool flag1=true,flag2=true;
int len1=strlen(a),len2=strlen(b);
if(len1<||len1>)
flag1=false;
else
{
for(int i=;i<len1;i++)
if(a[i]<''||a[i]>'')
{
flag1=false;
break;
}
}
if(len2<||len2>)
flag2=false;
else
{
for(int i=;i<len2;i++)
if(b[i]<''||b[i]>'')
{
flag2=false;
break;
}
}
int c=,d=;
if(flag1&&flag2)
{
for(int i=;i<len1;i++)
{
c=c*+a[i]-'';
}
for(int i=;i<len2;i++)
{
d=d*+b[i]-'';
}
if(c<||c>)flag1=false;
if(d<||d>)flag2=false;
}
if(flag1)cout<<a;
else cout<<"?";
cout<<" + ";
if(flag2)cout<<b;
else cout<<"?";
cout<<" = ";
if(flag1&&flag2)
{
cout<<c+d;
}
else cout<<"?";
cout<<endl;
return ;
}