//QUESTION
/*
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10^100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
*/
#include <stdio.h>
int ctoi(char num){//把一个char型数字,转化成int
return num - '0';
}
int main(){
int store[3];//store各位保存一个count的位数,因为count之和最大不过900,所以三位就够用
char num[100];//为了能够存下10^100,这么大个数。而C语言中整型数据类型没有能存得下的
scanf("%s",&num);
int i = 0;
int count = 0;
while(num[i] != '\0'){
count += ctoi(num[i]);
i ++;
}
for(i = 0;count;i ++){
store[i] = count % 10;
count /= 10;
}
i--;
for(;i >= 0;i --){
switch(store[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;
}
if (store[i] != '\0')//此处尤为精妙,也是我没有意料到的
//
printf(" ");
else
printf("\n");
}
}