第二题稍微有些难度。
主要思路是
第一步,通过不断读入字符(以换行符为终止)减去‘0’,将结果累加。
第二步,将累加结果转换为数组(转换过后是低位到高位)。
第三步,从高位到低位遍历数组,输出数字对应的拼音。
我最开始采用了Switch-case语句来对应拼音和数字,觉得会比if-else语句更简洁,但还是复杂,参考了其他方法后,选择用字符串数组(指针)来存放拼音,再用之前得到的数字数组的元素,作为字符串数组的索引,这样做代码更加简洁。
#include<stdio.h>
int main(void){
int sum=0,a[101];
// 先用字符串数组存起来,再调用
char ch,*p[]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
while((ch=getchar())!='\n')
{
sum+=ch-'0';
}
int i=0;
while(sum){
a[i]=sum%10;
sum/=10;
i++;
}
for(i=i-1;i>=0;i--){
printf("%s",p[a[i]]);
if(i)
putchar(' ');
}
return 0;
}