读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。 输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10的100次幂。 输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。 输入样例: 1234567890987654321123456789 输出样例: yi san wu

时间:2022-05-25 01:04:36

这是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;
}

如有错误请给予指正,谢谢。