L1-025. 正整数A+B

xiaoxiao2021-02-28  47

本题的目标很简单,就是求两个正整数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: ? + ? = ?

题解:乍一看觉得还是很麻烦的,考虑了很多情况,方法是根据第一个空格出现的位置,把前后两个数分割,进行处理,写个函数的话代码更简练,我这里没用函数

#include <stdio.h> #include <string.h> int main(){ char emm[1000]; gets(emm); int k=strlen(emm); int temp; for(int i=0;i<=k-1;i++){ if(emm[i]==' ') { temp=i; break; } } int a=0; int flag=1; for(int i=0;i<=temp-1;i++){ if(!(emm[i]>='0'&&emm[i]<='9')){ flag=0; break; } else a=a*10+emm[i]-'0'; } if(!(a>=1&&a<=1000)) flag=0; int b=0; int fflag=1; for(int i=temp+1;i<=k-1;i++){ if(!(emm[i]>='0'&&emm[i]<='9')){ fflag=0; break; } else b=b*10+emm[i]-'0'; } if(!(b>=1&&b<=1000)) fflag=0; if(flag&&fflag) printf("%d + %d = %d\n",a,b,a+b); else{ if(flag) printf("%d + ",a); else printf("? + "); if(fflag) printf("%d = ?",b); else printf("? = ?\n"); } return 0; }
转载请注明原文地址: https://www.6miu.com/read-2620745.html

最新回复(0)