这是PAT中的一道练习题 刚开始的时候我想着直接定义正整数n,结果走了很大的弯路,因为题目中要求n小于10的100次幂,即最大的正整数n有100位,而C语言中整型数字最大占8个字节的存储空间,如果按无符号整数算的话,其最大为2的64次幂,远小于10的100次幂,这样当输入夫人数字n很大时,就不符合题目要求。
所以,我想到了另一种方法,就是将自然数n存储到数组当中,给予数组足够的空间,然后再计算过程中在进行数组和数字之间的转化即可,具体代码如下:
using namespace std;
#include<iostream>
int main()
{
char b[100];
int num[3];
char ch[10][5]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
int sum=0,i;
scanf("%s",b);
for(i=0;b[i]!='\0';i++)
{
sum+=b[i]-'0';
}
i=0;
while(sum!=0)
{
num[i]=sum%10;
sum=sum/10;
i++;
}
i--;
while(i>0)
{
printf("%s",ch[num[i]]);
printf(" ");
i--;
}
printf("%s",ch[num[i]]);
return 0;
}
如有错误请给予指正,谢谢。