读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10
100
。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
int main(){
int sum = 0;
int n = 0;
char c = '0';
for(sum=0;(c=getchar())!='\n';sum=sum+n){//获取输入的数字直到回车键入
n = c - '0';//每输入一个字符 使用ascii码相减得到整型类n
}
int k = 1;
while(sum/k>=10){//根据sum除以k可以得到sum的位数,sum为两位数则k=10,sum为三位数则k=100,以此类推
k *= 10;
}
for(;k>=1;k/=10){//k从大到小
int m = sum / k;//sum/k可以得到sum的最高位
sum = sum % k;//剔除sum的最高位得到新的sum
switch(m){
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;
}
if(k>=10){
printf(" ");//在每一次打印后添加空格
}
}
return 0;
}