PAT B1002

读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。

输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100

输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。

输入样例:
1234567890987654321123456789
输出样例:
yi san wu

#include "stdio.h"
//#include "math.h"
#include "string.h"
//#include "algorithm"
//using namespace std;
char map[10][5]={"ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu"};
int main(){
    char str[110];
    gets(str);
    int sum = 0,len = strlen(str);
    for (int i = 0; i < len; i++) {
        sum += str[i] - '0';
    }
    int num = 0,ans[31];
    do{
        ans[num++] = sum %10;
        sum /= 10;
    }while(sum);
    for (int i = num - 1; i >= 0; i--) {
        printf("%s", map[ans[i]]);
        if (i) {
            printf(" ");
        }
    }
    return 0;
}