题目描述:
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
解题思路:
此题难点在输出。
解法首先将字符串输入,然后按顺序把每位数相加得到总和num。随后做一个数组,设置i控制位数将num按位倒序输入给数组,i即为数组的长度,最后重后往前遍历并识别数字输出拼音,每一个数字后输出空格,最后一个数后将空格改为换行输出即可。
下面是AC后的代码:
#include<stdio.h>
#include<string.h>
int main()
{
int i, x, num=0, a[10010]={0};
char str[10010];
gets(str);
x = strlen(str);
for(i=0;i<x;i++)
num += str[i]-48;
x = 0;
while(num)
a[x]=num%10, num/=10, x++;
for(i=x-1;i>=0;i--)
{
switch(a[i]){
case 0 : printf("ling");break;
case 1 : printf("yi");break;
case 2 : printf("er");break;
case 3 : printf("san");break;
case 4 : printf("si");break;
case 5 : printf("wu");break;
case 6 : printf("liu");break;
case 7 : printf("qi");break;
case 8 : printf("ba");break;
case 9 : printf("jiu");break;
}
(i != 0) ? printf("\x20") : printf("\n");
}
return 0;
}