HDU 1228 A + B
来源:互联网 发布:手机淘宝网触屏版官网 编辑:程序博客网 时间:2024/04/30 21:51
题目链接 HDU 1228
A + B
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 13582 Accepted Submission(s): 8032
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
39096
Source
浙大计算机研究生复试上机考试-2005年
map,string的应用,废话不多,见代码。
代码:
#include <cstdio>#include <string>#include <map>#include <iostream>using namespace std;int main(){ map<string, int> M; M["ze"] = 0; //单词对应到数字,这里只取前个字符 M["on"] = 1; M["tw"] = 2; M["th"] = 3; M["fo"] = 4; M["fi"] = 5; M["si"] = 6; M["se"] = 7; M["ei"] = 8; M["ni"] = 9; char ch[200]; while(1) { gets(ch); int s1 = 0, s2 = 0, ok = 1; string str = ""; //保存每个单词的前两个字符 str += ch[0]; str += ch[1]; for(int i = 0; ch[i]; i++) { if(ch[i] == '+') //遇到加号,后面的为s2的值 { ok = 0; str = ""; str += ch[i + 2]; str += ch[i + 3]; continue; } if(ch[i] != ' ' && ch[i + 1] == ' ') //这个单词结束了,将他的值累加起来 { if(ok) s1 = 10 * s1 + M[str]; else s2 = 10 * s2 + M[str]; str = ""; str += ch[i + 2]; str += ch[i + 3]; } } if(s1 + s2 == 0) break; printf("%d\n", s1 + s2); } return 0;}
1 0
- hdu 1228A+B
- HDU 1228 ( A + B )
- hdu 1228 A + B
- hdu 1228 A + B
- HDU 1228 A+B
- hdu 1228A + B
- HDU-1228A+B
- hdu 1228 A + B
- hdu 1228-A+B
- hdu 1228 A + B
- hdu 1228 A+B
- hdu-1228-A + B
- hdu 1228 A + B
- hdu 1228 A+B
- hdu 1228 A + B
- hdu 1228 A + B
- hdu 1228 A + B
- HDU 1228 A + B
- HTML--Note6--form
- HDOJ 1089 A+B for Input-Output Practice (I)(水题)
- 什么是Spark?
- 看看C# 6.0中那些语法糖都干了些什么(终结篇)
- AWK学习笔记
- HDU 1228 A + B
- 看看C# 6.0中那些语法糖都干了些什么(中篇)
- c++静态成员
- POJ_1915_KnightMoves
- 看看C# 6.0中那些语法糖都干了些什么(上篇)
- bzoj3992: [SDOI2015]序列统计
- android 目前遇到的程序崩溃常见原因
- 《TCP/IP入门经典》——网际层
- Java IO学习【7】BufferedReader的学习-readLine原理