读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:1234567890987654321123456789输出样例:
yi san wu
#include "iostream" #include <sstream> using namespace std; int main(int argc, char* argv[]) { int i = 0; int num = 0; string input; string output = ""; string strnum; cin >> input; ostringstream oss; for (i = 0; i < input.length(); i++) // 实现一串数字的输入 { num += (input[i] - 48); } oss << num; // 将整型转换成字符串 strnum = oss.str(); for (i = 0; i < strnum.length(); i++) { switch (strnum[i] - 48) { case 0: output += "ling"; break; case 1: output += "yi"; break; case 2: output += "er"; break; case 3: output += "san"; break; case 4: output += "si"; break; case 5: output += "wu"; break; case 6: output += "liu"; break; case 7: output += "qi"; break; case 8: output += "ba"; break; case 9: output += "jiu"; break; } if (i < strnum.length() - 1) output += " "; } cout << output; return 0; }