还是A+B
时间限制:
1000 ms | 内存限制:
65535 KB
难度:
1
-
描述
-
输入两个小于100的正整数A和B,输出A+B;A,B均为每位数字对应的英文字母,结果为十进制数。
-
输入
- A,B。 输出
- A+B; 样例输入
-
one + two = one + two zero =
样例输出
-
3 21
很久之前就见到这个题了,但是之前字符串还不会处理,就放在那了,然后今天把它扒出来了做了一遍....然后方法很复杂,错了好多次...唉...
然后简化一下思路,结果代码简化了,竟然也 ac 了.....
不想用暴力查找,就用map 直接对应关系,然后处理就可以了,比较简练,另外,在处理的时候,这个题给的比较简单,每个字符串都间隔的有空格,如果是连续的就比较复杂了,而且给出的最多两位数的运算,比较简单的判断符号就可以了,具体看代码注释....
#include<stdio.h>
#include<string.h>
#include<string>
#include<map>
using namespace std;
int main()
{
map<string,int> map;
map["zero"]=0;map["one"]=1;map["two"]=2;map["three"]=3;map["four"]=4;
map["five"]=5;map["six"]=6;map["seven"]=7;map["eight"]=8;map["nine"]=9;
char a[105],b[105];
//freopen("shuju.txt","r",stdin);
while(~scanf("%s%s",a,b))
{
int x,y;
x=map[a];
if(b[0]!='+')
{
x=x*10+map[b];
scanf("%s",a);
}
scanf("%s%s",a,b);
y=map[a];
if(b[0]!='=')
{
y=y*10+map[b];
scanf("%s",a);
}
printf("%d\n",x+y);
}
return 0;
}