hdu 1228-A+B

题目传送门

[https://vjudge.net/contest/226293#status/mch5201314/E/0/]

题意:

读入两个小于100的正整数A和B,计算A+B.
需要注意的是:A和B的每一位数字由对应的英文单词给出.
测试输入包含若干测试用例,每个测试用例占一行,格式为"A + B =",相邻两字符串有一个空格间隔.当A和B同时为0时输入结束,相应的结果不要输出.

思路:

把要处理的等式当做一个字符串,然后用一个s1字符数组记录出现的小写字母,当遇到空格时代表一个单词结束,
然后用这个单词和每个数字的单词进行比较,找出这个单词代表的数字是多少,记录下数字后将s1中的元素清除,再次从s1[0]开始保存单词,直到字符串结束,找出 + 前后两部分各代表的整数。

代码:

#include<stdio.h>
#include<string.h>
int main()
{
    char str[30],s1[20];
    int i,j,len,s,sum1,sum2,flag;
    while(gets(str)!=NULL)
    {
        len=strlen(str);
        sum1=sum2=0; 
        flag=0; 
        for(i=0,j=0;i<len;i++)
        {
            if(str[i]>='a'&&str[i]<='z')  /*如果是小写字母*/
                s1[j++]=str[i];  /*保存在s1中*/
            else if(str[i]==' '&&str[i-1]!='+')   /*判断str[i-1]!='+'是为了避免将 + 当做一个字符串处理*/
            {
                s1[j]='\0'; /*千万不能忘记字符串结束标志*/
                if(!strcmp(s1,"zero")) s=0; 
                else if(!strcmp(s1,"one")) s=1;
                else if(!strcmp(s1,"two")) s=2;
                else if(!strcmp(s1,"three")) s=3;
                else if(!strcmp(s1,"four")) s=4;
                else if(!strcmp(s1,"five")) s=5;
                else if(!strcmp(s1,"six")) s=6;
                else if(!strcmp(s1,"seven")) s=7;
                else if(!strcmp(s1,"eight")) s=8;
                else if(!strcmp(s1,"nine")) s=9; /*比较字符串,找出代表的数字*/
                j=0;  /*记得从零开始*/
                if(!flag)
                    sum1=sum1*10+s; /*sum1保存 + 前面部分代表的数字*/
                else 
                    sum2=sum2*10+s; /*sum2保存 + 后面部分代表的数字*/
            }
            else if(str[i]=='+')
                flag=1;  /*标记 + 已出现*/
        }
        if(sum1==0&&sum2==0) /*两个数都是0时结束程序*/
            break; 
        else
            printf("%d\n",sum1+sum2);
    }
    return 0;
}

猜你喜欢

转载自www.cnblogs.com/mch5201314/p/9385593.html