题目
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10的100次方
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
代码
#include<stdio.h>
int main()
{
int sum=0,num;
char arr[3]={'x','x','x'};
int i;
while((num=getchar())!='\n')
sum=sum+num-'0';
for(i=0;sum>0;i++)
{
arr[i]=sum%10;
sum=sum/10;
}
for(i=2;i>=0;i--)
{
switch(arr[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;
default:
break;
}
if(arr[i]!='x'&&i!=0)
{
printf(" ");
}
}
return 0;
}
分析
做这个题的时候遇到两个问题,一个是10的100次方太大了,不能直接用用一个变量来存储,所以用读入一个计算一个数的方式来进行累加。第二个问题就是空格的输入,试了很多方法,最后想到用字符类型数组存储累加后的值也就是sum,提前给字符数组赋值,最后判定要不要输入空格的时候,如果这个值不是整数或者是最后一个整数就不输出空格。之所以这样做是因为数组必须先确定个数,而最后的sum可能是几百或几十或者几,有时候会输出ling ling liu之类的字符串。