HDU - 1228 A + B【C++,map题解】

原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=1228

A + B

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 21350    Accepted Submission(s): 12777

Problem Description
读入两个小于100的正整数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
浙大计算机研究生复试上机考试-2005年
 
Recommend
JGShining
 

题记:

    本题使用了STL中的map,把string类型的数字转化为对应int型的数字,然后进行计算。

    map的使用非常简单,话不多说,直接看代码吧。

C++代码:

#include 
#include  
#include 
using namespace std;
 
int main(){
    map num;
    num["zero"] = 0;
    num["one"] = 1;
    num["two"] = 2;
    num["three"] = 3;
    num["four"] = 4;
    num["five"] = 5;
    num["six"] = 6;
    num["seven"] = 7;
    num["eight"] = 8;
    num["nine"] = 9;
    
    int a, b;
    string s;
    
    for( ; ; ) {
        a = 0;  //a存放+号前的数
        while(cin >> s) {
            if(s=="+"){
            	break;
			}  
            a = a * 10 + num[s];
        }
        
        b = 0;  //b存放+号后的数
        while(cin >> s) {
            if(s == "="){
            	 break;
			} 
            b = b * 10 + num[s];
        }
        
        if(a == 0 && b == 0){
        	break;
		}else{
        	cout << a + b << endl;
		} 
    }
    
    return 0;
}

 

你可能感兴趣的:(HDU,STL,字符串处理)