A + B
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 7340 Accepted Submission(s): 4142
Problem Description
读入两个小于100的正整数A和B,计算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
Source
我的代码
#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;
int finds(char *str,int i)
{
int tmp;
switch(str[i])
{
case 'z':
tmp=0;break;
case 'o':
tmp= 1;break;
case 't':
if(str[i+1]=='w') tmp= 2;
if(str[i+1]=='h') tmp= 3;
if(str[i+1]=='e') tmp= 10;break;
case 'f':
if(str[i+1]=='o')tmp= 4;
if(str[i+1]=='i')tmp= 5;break;
case 's':
if(str[i+1]=='i')tmp= 6;
if(str[i+1]=='e')tmp= 7;break;
case 'e':
tmp= 8;break;
case 'n' :
tmp= 9;break;
}
return tmp;
}
int trans(char *str,int s,int e)
{
int t=finds(str,s);
while(str[s]!=' ')s++;
s++;
// printf("[%d]\n",t);
if(s<e)
{
t*=10;
t+=finds(str,s);
}
return t;
}
int main()
{
int i,j;
char s[99];
while(gets(s))
{
int a,b;
for(i=0;i<strlen(s);i++)
if(s[i]=='+')
break;
a=trans(s,0,i-1);
b=trans(s,i+2,strlen(s)-2);//注意这里是加2,越过加号右边的空格
if(a+b==0)
break;
printf("%d\n",a+b);
}
return 0;
}
/**************************************************************
Problem: 1010
User: HCA1101
Language: C++
Result: Accepted
Time:0 ms
Memory:1520 kb
****************************************************************/