DAY2
题目
1002 写出这个数
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
#include <stdio.h>
#include <string.h>
int invert_char_num(char *num)
{
int i=0,sum=0;
while(num[i]!='\0')
{
sum=sum+(num[i]-'0');
i++;
}
return sum;
}
void write_num(int num)
{
int str[32];
int i=0;
while(num!=0)
{
str[i]=num%10;
num/=10;
i++;
}
for(int j=i-1;j>=0;j--)
{
if(str[j]==0)
{
printf("ling ");
}
else if(str[j]==1)
{
printf("yi ");
}
else if(str[j]==2)
{
printf("er ");
}
else if(str[j]==3)
{
printf("san ");
}
else if(str[j]==4)
{
printf("si ");
}
else if(str[j]==5)
{
printf("wu ");
}else if(str[j]==6)
{
printf("liu ");
}
else if(str[j]==7)
{
printf("qi ");
}
else if(str[j]==8)
{
printf("ba ");
}
else if(str[j]==9)
{
printf("jiu ");
}
}
printf("\b \n");
}
int main()
{
char number[32]={0};
int sum=0;
gets(number);
sum=invert_char_num(number);
write_num(sum);
return 0;
}
总结
在这里用数组存储了gets()函数获得的超长字符串,但是很容易溢出,并且gets()容易报错,但暂时想不到更好的办法。
对写函数逻辑进行了优化:
void write_num(int sum)
{
char word[10][5]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
int tmpword[32];
int i=1;
while(sum!=0)
{
tmpword[i]=sum%10;
sum/=10;
i++;
}
i--;
while(i!=0)
{
printf("%s ",word[tmpword[i]]);
i--;
}
printf("\b \n");
}