[题目链接(https://pintia.cn/problem-sets/994805260223102976/problems/994805324509200384)
《算法笔记》给出的答案是这样的:
#include <cstdio>
#include <cstring>
int main(){
char str[110];
scanf("%s",str);
int len=strlen(str);
int sum=0;
for (int i=0; i<len; i++){
sum+=str[i]-48;
}
int num=0,ans[10];
while (sum){
ans[num++]=sum%10;
sum/=10;
}
char change[10][5]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
for (int i=num-1;i>=0; i--){
printf("%s",change[ans[i]]);
if (i) printf(" ");
}
能通过测试,但感觉这个代码并不完美,将sum这个数的各位存到数组ans[]的这个代码段,有点瑕疵,如果sum==0,那么ans[]将什么都不存,而实际上,ans[]应该存一个0;所以这里用do{}while ();结构应该更好(就想进制转化那样);
所以我觉得下面的代码可能更好:
#include <cstdio>
#include <cstring>
int main(){
char n[110],chinese[][10]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
scanf("%s",n);
int sum=0;
for (int i=0; i<strlen(n); i++){
sum+=n[i]-48;
}
int num=0,ans[110];
do{
ans[num++]=sum%10;
sum/=10;
}while (sum);
printf("%s",chinese[ans[--num]]);
for (--num; num>=0; num--){
printf(" %s",chinese[ans[num]]);
}
但是两个代码都能通过评测,只不过前一个代码如果输入是0,计算机将什么都不输出,但是后一个代码如果输入是0,计算机将输出ning。可以看出,测评机没有将0当作一组数据来评测,所以第一种代码能通过是一种侥幸。