读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10^100^。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
实现代码:
#include<stdio.h>
#define N 100
#define M 5
int main(){
char numChar[10][5]={"ling","yi","er","san",
"si","wu","liu","qi","ba","jiu"};
char array[N];
int sum=0,i=0,j;
int index[M];
for(i=0;i<M;i++)
index[i]=-1;
scanf("%s",array);
i=0;
while(array[i]!='\0'){
sum+=array[i]-'0';
i++;
}
j=0;
while(sum>0){
index[j]=sum%10;
sum=sum/10;
j++;
}
for(i=M-1;i>=0;i--){
if(index[i]!=-1){
if(i==0)
printf("%s",numChar[index[i]]);
else
printf("%s ",numChar[index[i]]);
}
}
return 0;
}
心得:
刚开始用整型,发现整型并不能用题目所要求的的位数,所以参考网上代码用了字符串。
该例子中,sum的最大位数为5
字符串上得到各个数的数值用c-'0'
'\0'表示空格,此时该位数无数值
用sum%10得到sum每个位置的数值,然后用sum/10得到去除最末位后的数,存进index中
若index为-1,不做处理。否则为numChar上相应的汉字
到最末位时,汉字后不需加空格