题目
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10^100.
输出格式
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例
1234567890987654321123456789
输出样例
yi san wu
思路
将每一个数字对应的拼音保存在一个数组当中 将给定的数字保存在数组中并计算总和 分解得到的多项式每一位将其保存在一个新的数组中
#include <bits/stdc++.h> #define maxn 10005 using namespace std; char a[maxn]; int b[maxn]; char pinyin[15][5] = {"ling","yi","er","san","si","wu","liu","qi","ba","jiu"}; int main() { scanf("%s",a); int len = strlen(a); int sum = 0; for(int i = 0;i<len;i++){ sum += a[i] - '0'; } int x = 0; int q = 0; while(sum != 0){ x = sum % 10; b[q] = x; q++; sum /= 10; } for(int i = q - 1;i >= 0;i--){ printf("%s",pinyin[b[i]]); if(i != 0) printf(" "); } cout << endl; return 0; }