1002 写出这个数 (20分)
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
代码
#include<iostream>
#include<string>
using namespace std;
struct MyMap{
int num;
string CN;
void set(int n,string c){
num = n;
CN = c;
}
};
void printCN(int n,MyMap *m){
// 递归到第一位时,输出不含空格
if(n<10){
cout<<m[n].CN;
return;
}
// 每次递归右移
n = n/10;
printCN(n,m);
// 非最高位时就输出最低位。
if(n>10){
int tmp = n%10;
cout<<" "<<m[tmp].CN;
}
}
int main(){
string s;
int sum = 0;
cin>>s;
MyMap *m1 = new MyMap[10];
m1[0].set(0,"ling");
m1[1].set(1,"yi");
m1[2].set(2,"er");
m1[3].set(3,"san");
m1[4].set(4,"si");
m1[5].set(5,"wu");
m1[6].set(6,"liu");
m1[7].set(7,"qi");
m1[8].set(8,"ba");
m1[9].set(9,"jiu");
for(int i=0;i<s.length();i++){
char n = s[i];
int number = n - '0';
sum += number;
}
// sum*10是为了防止最后一位被删掉
printCN(sum*10,m1);
return 0;
}