PAT L1 025 正整数A+B
2018-03-10 16:11
288 查看
问题描述:
这个题其实考的不是加数,而是输入的判断
输入数据有可能是负数,带小数点,乱码
这些可以通过char模拟然后观察每个字符是否在0-9之间来解决
输入数据有可能是超出范围的数字>1000或者等于0
将char转换成int 然后判断即可
以下为ac代码:
本题的目标很简单,就是求两个正整数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: ? + ? = ?
这个题其实考的不是加数,而是输入的判断
输入数据有可能是负数,带小数点,乱码
这些可以通过char模拟然后观察每个字符是否在0-9之间来解决
输入数据有可能是超出范围的数字>1000或者等于0
将char转换成int 然后判断即可
以下为ac代码:
#include<cstdio> #include<cstdlib> #include<cmath> #include<cstring> #include<iostream> #include<algorithm> #include<queue> #include<map> #include<stack> #include<set> using namespace std; typedef long long ll; typedef unsigned long long ull; const int Max_N=1000010; char ww[100000]; int main(){ ios::sync_with_stdio(false); while(gets(ww)){ int len=strlen(ww); int a=0; int b=0; int i; int flag=0; for(i=0;ww[i]!=' '&&!flag;i++){ if(ww[i]>='0'&&ww[i]<='9') a=a*10+ww[i]-'0'; else flag=1; } if(a>1000||a==0) flag=1; int flag2=0; i=i+1; for(;i<len&&!flag2;i++){ if(ww[i]>='0'&&ww[i]<='9') b=b*10+ww[i]-'0'; else flag2=1; } if(b>1000||b==0) flag2=1; if(flag==0) cout<<a; else cout<<"?"; cout<<" + "; if(flag2==0) cout<<b; else cout<<"?"; cout<<" = "; if(flag==0&&flag2==0) cout<<a+b<<endl; else cout<<"?"<<endl; } return 0; }
相关文章推荐
- [PAT][GPLT][CCCC]L1-025.正整数A+B
- pat L1-025. 正整数A+B
- PAT L1-025. 正整数A+B
- PAT 天梯赛 L1-025. 正整数A+B 【字符串处理】
- Java - PAT - L1-025. 正整数A+B (天梯赛决赛题目)
- PAT-练习集-L1-025. 正整数A+B
- PAT-团体程序设计天梯赛-练习集-L1-025. 正整数A+B
- L1-025. 正整数A+B-PAT团体程序设计天梯赛GPLT
- PAT L1-025. 正整数A+B
- L1-025. 正整数A+B-PAT团体程序设计天梯赛GPLT
- PAT -天梯赛 L1-025 正整数A+B
- PAT-L1-025. 正整数A+B
- L1-025. 正整数A+B - PAT - assign函数的用法
- PAT团体程序设计天梯赛L1-025 正整数A+B
- L1-025. 正整数A+B
- L1-025. 正整数A+B【未完成】
- L1-025. 正整数A+B
- L1-025. 正整数A+B
- L1-025. 正整数A+B 简单复习一下,。
- L1-025. 正整数A+B