594 还是A+B【map】
来源:互联网 发布:java生成uml类图 编辑:程序博客网 时间:2024/06/06 09:39
还是A+B
时间限制:1000 ms | 内存限制:65535 KB
难度:1
- 描述
- 输入两个小于100的正整数A和B,输出A+B;A,B均为每位数字对应的英文字母,结果为十进制数。
- 输入
- A,B。
- 输出
- A+B;
- 样例输入
one + two =one + two zero =
- 样例输出
321
很久之前就见到这个题了,但是之前字符串还不会处理,就放在那了,然后今天把它扒出来了做了一遍....然后方法很复杂,错了好多次...唉...
然后简化一下思路,结果代码简化了,竟然也 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;}
0 0
- 594 还是A+B【map】
- nyoj 594-还是A+B
- NYOJ 594 还是A+B
- NYOJ 594 还是A+B
- NYOJ 594题 还是A+B
- nyoj 594 还是A+B 【字符串】
- 1229 还是A+B
- HDU1229-还是A+B
- zju2006还是a+b
- HDU1229:还是A+B
- hoj 还是A+B
- 还是A+B
- HDU1229 还是A+B
- NYOJ594 还是A+B
- NXOJACM:还是a+b
- 1015.还是A + B
- 还是A+B
- 还是A+B
- 安卓入门
- C#贪吃蛇
- 求最大子序列和的四种方法
- spring标签-util:properties
- iOS开发常见问题集
- 594 还是A+B【map】
- The Java EE 6 Tutorial Finalizing a Servlet
- iOS8与iOS9的不同
- STL之map、set数据结构基础
- PAT 1071. Speech Patterns (25)
- 简单实用POP动画
- 面试题5:从尾到头打印链表
- 正则表达式学习
- C语言 函数指针