/*1002 写出这个数 (20)(20 分)
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10^100^。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
*/
#include<stdio.h>
#include<math.h>
#include<string.h>
int main(void)
{
int sum=0,len=1,i=1,t[100];
char p[1000000],q;
gets(p);
for(int i=0;i<strlen(p);i++)
sum+=(p[i]-48);
while(sum/(int)(pow(10.0,(double)i))!=0)
{
i++;
len=i;
}
for(int i=0;i<len;i++)
t[i]=(sum/(int)(pow(10.0,(double)(len-i-1))))%10;
for(int i=0;i<(len-1);i++)
{
switch(t[i])
{
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;
case 0:
printf("ling ");
break;
}
}
switch(t[len-1])
{
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;
case 0:
printf("ling");
break;
}
return 0;
}