读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例: 1234567890987654321123456789
输出样例: yi san wu
#include <stdio.h> #include <algorithm> #include <string> #include <map> #include <iostream> #include <stack> using namespace std; int main(){ map<int, string> mp; mp[1] = "yi"; mp[2] = "er"; mp[3] = "san"; mp[4] = "si"; mp[5] = "wu"; mp[6] = "liu"; mp[7] = "qi"; mp[8] = "ba"; mp[9] = "jiu"; mp[0] = "ling"; string s; cin >> s; int sum = 0; for (int i = 0; i < s.length(); i++){ sum += int(s[i]-'0'); } stack<int> stk; while (sum != 0){ int tmp = sum % 10; sum /= 10; stk.push(tmp); } while (!stk.empty()){ int tmp = stk.top(); stk.pop(); if (stk.empty()){ //printf("%s", mp[tmp]); cout << mp[tmp]; } else{ //printf("%s ", mp[tmp]); cout << mp[tmp]<<' '; } } //cout << endl<< mp[0]; system("pause"); }
注意点:用了stack和map,其实根本不需要,储存0-9的拼音直接用一个string[10]就行了,因为刚好下标是对应的。而题目里10的100次方加和最大是9*100,不会超过3位数,因此也可以不用stack,直接一个int[3]就可以了,用vector也可以,遍历vector用vi.begin,vi.end。
----------------
坚持每天学习一点点