7-27 正整数A+B (15 分)

题的目标很简单,就是求两个正整数AB的和,其中AB都在区间[1,1000]。稍微有点麻烦的是,输入并不保证是两个正整数。

输入格式:

输入在一行给出AB,其间以空格分开。问题是AB不一定是满足要求的正整数,有时候可能是超出范围的数字、负数、带小数点的实数、甚至是一堆乱码。

注意:我们把输入中出现的第1个空格认为是AB的分隔。题目保证至少存在一个空格,并且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(){
    int i,flag1=0,flag2=0,num1=0,sum=0;
    char ch;
    i=0;
    while((ch=getchar())!=' '){
        if(!flag1&&ch!=' '){
            if(ch>='0'&&ch<='9')
                sum=sum*10+ch-'0';
            else{
                flag1=1;
            }
        }
        if(sum<1 || sum >1000)flag1=1;
        i++;
    }
    flag1?printf("? + ") :printf("%d + ",sum);
    num1=sum;
    sum=0;
    i=0;
    while((ch=getchar())!='\n'){
        if(!flag2&&ch!=' '){
            if(ch>='0'&&ch<='9')
                sum=sum*10+ch-'0';
            else{
                flag2=1;
            }
        }
        if(sum<1 || sum >1000)flag2=1;
        i++;
    }
    flag2?printf("? = ") :printf("%d = ",sum);
    (!flag1 && !flag2)?printf("%d",num1+sum):printf("?");
    return 0;
}

上一篇:2021-11-27学习笔记


下一篇:27.泛型-反射-注解