题目链接在此。
原来我之前记录过这个题目,看完之前自己的做法,在题目最后加了一个“Stupid!”,晕+_+,不过对题目的考虑还是都到位了。
题意没什么可说的。
思路:用%运算拿到和的最后一位,每次/=10即可。 数字转换成拼音,用打表的方法可以使代码更简洁。 为了倒序输出每一位对应的拼音,把每一位先存放在一个数组中,方便后续输出。
#include<stdio.h>
#include<string.h>
char mp[10][10] = {"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
int main(){
char n[105];
int sum = 0;
scanf("%s",n);
for(int i = 0 ;i < strlen(n); i++){
sum += n[i] - '0';
}
int num = 0, res[strlen(n)];
do{
res[num++] = sum%10;
sum /= 10;
}while(sum != 0);
for(int i = num-1; i >= 0; i--){
if(i == 0){
printf("%s",mp[res[i]]);
}else{
printf("%s ",mp[res[i]]);
}
}
return 0;
}
注意:根据题目n的范围,字符数组n[]至少要开到100才够用