hdu 1228java_hdu 1228-A+B

A + B

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)

Problem Description

读入两个小于100的正整数A和B,计算A+B.

需要注意的是:A和B的每一位数字由对应的英文单词给出.

Input

测试输入包含若干测试用例,每个测试用例占一行,格式为"A + B =",相邻两字符串有一个空格间隔.当A和B同时为0时输入结束,相应的结果不要输出.

Output

对每个测试用例输出1行,即A+B的值.

Sample Input

one + two =

three four + five six =

zero seven + eight nine =

zero + zero =

Sample Output

3

90

96

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

AC代码:

#include

#include

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

{

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;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值