L1-025. 正整数A+B
2018-03-22 20:46
357 查看
题目描述
本题的目标很简单,就是求两个正整数A和B的和,其中A和B都在区间[1,1000]。稍微有点麻烦的是,输入并不保证是两个正整数。
输入
输入在一行给出A和B,其间以空格分开。问题是A和B不一定是满足要求的正整数,有时候可能是超出范围的数字、负数、带小数点的实数、甚至是一堆乱码。
注意:我们把输入中出现的第1个空格认为是A和B的分隔。题目保证至少存在一个空格,并且B不是一个空字符串。
输出
如果输入的确是两个正整数,则按格式“A + B = 和”输出。如果某个输入不合要求,则在相应位置输出“?”,显然此时和也是“?”。
样例输入1
样例输出1
样例输入2
样例输出2
样例输入3
样例输出3
思路
这道题的考点就是如何输入所给数据
先用scanf()输入a 不输入第一个空格
再用gets()输入b 直到 \n 输入结束
代码
本题的目标很简单,就是求两个正整数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
? + ? = ?
思路
这道题的考点就是如何输入所给数据
先用scanf()输入a 不输入第一个空格
再用gets()输入b 直到 \n 输入结束
代码
#include <bits/stdc++.h> using namespace std; char A[10000], B[10000]; int convert(char* str){ int sum = 0; for(int i=0; str[i]!='\0'; i++){ if(str[i]>='0' && str[i]<='9'){ sum = sum*10+(str[i]-'0'); }else { return -1; //如果返回-1,表示输入不合法 } } if(sum>=1 && sum<=1000){ return sum; }else { return -1; } } int main(){ int a, b; scanf("%s ", &A); gets(B); a = convert(A); b = convert(B); if(a == -1){ cout<<"? + "; }else { printf("%d + ", a); } if(b == -1){ cout<<"? = "; }else { printf("%d = ", b); } if(a==-1 || b==-1){ printf("?"); }else { cout<<a+b; } return 0; }
相关文章推荐
- pat L1-025. 正整数A+B
- L1-025. 正整数A+B
- L1-025. 正整数A+B
- PAT L1-025. 正整数A+B
- L1-025. 正整数A+B
- L1-025. 正整数A+B【未完成】
- PAT -天梯赛 L1-025 正整数A+B
- L1-025. 正整数A+B
- L1-025. 正整数A+B
- 团体程序设计天梯赛L1-025 正整数A+B
- L1-025. 正整数A+B
- PAT L1 025 正整数A+B
- 【天梯赛】L1-025. 正整数A+B
- L1-025. 正整数A+B
- L1-025. 正整数A+B
- PAT-团体程序设计天梯赛-练习集-L1-025. 正整数A+B
- L1-025. 正整数A+B-PAT团体程序设计天梯赛GPLT
- L1-025. 正整数A+B
- L1-025. 正整数A+B
- L1-025. 正整数A+B