L1-025. 正整数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:
22. 18
输出样例2:
? + 18 = ?
输入样例3:
-100 blabla bla…33
输出样例3:
? + ? = ?
属性 | 要求 | 属性 | 要求 |
---|---|---|---|
时间限制 | 400 ms | 内存限制 | 65536 kB |
代码长度限制 | 8000 B | 判题程序 | Standard |
解析:
看清楚红字标出来的注意,意思是不管有几个空格,都只以第一个空格为界限!第一个空格之前是第一个数,第一个空格之后,不管是不是空格,都属于第二个数的范围。
我在下边两个答案中都把if(a[j]==' ') break;
注释掉了,就是因为这个注意,不需要判断第二个空格是否存在了。
答案1:
这个答案设置了中间量x和y。在代码中m是第一个空格之前所有字符串的和,n是第一个空格之后所有字符串的和,而x是第一个空格之前所有数字的和,y是之后数字的和,如果m=x,n=y证明其中除了数字没有其他字符,只是单纯的数字。
#include<iostream>
#include<string>
using namespace std;
int main()
{
string a;
getline(cin,a);
int m=0,n=0;//所有字符串的和
int x=0,y=0;//只有数字的和
int i=0;
for(i;i<a.length();i++)
{
if(a[i]==' ') break;
m=m*10+(a[i]-'0');
if(a[i]>='0'&&a[i]<='9')
{
x=x*10+(a[i]-'0');
}
}
for(int j=i+1;j<a.length();j++)
{
//if(a[j]==' ') break;
n=n*10+(a[j]-'0');
if(a[j]>='0'&&a[j]<='9')
{
y=y*10+(a[j]-'0');
}
}
if(m<=1000&&m>=1&&m==x)
cout<<m;
else
cout<<"?";
cout<<" + ";
if(n<=1000&&n>=1&&n==y)
cout<<n;
else
cout<<"?";
cout<<" = ";
if(n<=1000&&n>=1&&m<=1000&&m>=1&&m==x&&n==y)
cout<<m+n;
else
cout<<"?";
return 0;
}
答案2:
这个答案中求了所有字符的和,但是如果不是数字,又加了1050,因为m=m*10+(a[i]-'0');
这个可能是负数,0的ASCII码是48,所以我凑整1050(任何大于1049的数字都可以),防止出现0以前的字符影响结果。比如输入1 +
时候。
#include<iostream>
#include<string>
using namespace std;
int main()
{
string a;
getline(cin,a);
int m=0,n=0;
int i=0;
for(i;i<a.length();i++)
{
if(a[i]==' ') break;
m=m*10+(a[i]-'0');
if(!(a[i]>='0'&&a[i]<='9'))
{
m+=1050;
}
}
for(int j=i+1;j<a.length();j++)
{
//if(a[j]==' ') break;
n=n*10+(a[j]-'0');
if(!(a[j]>='0'&&a[j]<='9'))
{
n+=1050;
}
}
if(m<=1000&&m>=1)
cout<<m;
else
cout<<"?";
cout<<" + ";
if(n<=1000&&n>=1)
cout<<n;
else
cout<<"?";
cout<<" = ";
if(n<=1000&&n>=1&&m<=1000)
cout<<m+n;
else
cout<<"?";
return 0;
}