直接上题目,,略无聊。。
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 12635 Accepted Submission(s): 7407
one + two = three four + five six = zero seven + eight nine = zero + zero =
3 90 96
主要思想就是输入考虑加号前,等号前的两个字符窜情况,即输入两个字符窜。上代码附详细解析。
#include <stdio.h> #include <string.h> int main() { while(1) //多组数据 { int sum=0,i; int x=0; char a[5000]; int b[5000]; // 用一个整型数组存放数字 int l=0; int d[5000];//同上 memset(b,0,sizeof(b));//初始化 memset(d,0,sizeof(d));//同上 while(scanf("%s",a)&&strcmp(a,"+")!=0)//先输入一个字符窜 如果等于+就跳出 { if(strcmp(a,"zero")==0) b[l++]=0; if(strcmp(a,"one")==0) b[l++]=1; if(strcmp(a,"two")==0) b[l++]=2; if(strcmp(a,"three")==0) b[l++]=3; if(strcmp(a,"four")==0) b[l++]=4; if(strcmp(a,"five")==0) b[l++]=5; if(strcmp(a,"six")==0) b[l++]=6; if(strcmp(a,"seven")==0) b[l++]=7; if(strcmp(a,"eight")==0) b[l++]=8; if(strcmp(a,"nine")==0) b[l++]=9; }//以上比较各个字符窜是否等于相应的单词,等于的话直接将数字存入数组。 for(i=0;i<l;i++) x=x*10+b[i];// 这里是关键,比如three four 算法是0*10+3 x=3。x=3*10+4 。x=34。 sum+=x; x=0; l=0;//重新赋值 char c[5000]; while(scanf("%s",c)&&strcmp(c,"=")!=0)//再输入另一个字符窜,等于等号的话就跳出。 { if(strcmp(c,"zero")==0) d[l++]=0; if(strcmp(c,"one")==0) d[l++]=1; if(strcmp(c,"two")==0) d[l++]=2; if(strcmp(c,"three")==0) d[l++]=3; if(strcmp(c,"four")==0) d[l++]=4; if(strcmp(c,"five")==0) d[l++]=5; if(strcmp(c,"six")==0) d[l++]=6; if(strcmp(c,"seven")==0) d[l++]=7; if(strcmp(c,"eight")==0) d[l++]=8; if(strcmp(c,"nine")==0) d[l++]=9; } for(i=0;i<l;i++) x=x*10+d[i];//方法都上。。 sum+=x;//加到的sum就是最后答案。 if(sum) printf("%d\n",sum);//如果sum真,就输出。 else return 0;//否则就跳出去。 memset(b,0,sizeof(b)); memset(d,0,sizeof(d));//继续初始化为了保险。 } return 0; }
原文地址:http://blog.csdn.net/sky_miange/article/details/42191933