读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
本题要点:
1.输入是一个double,然而double类型的不能使用mod来求和,所以使用char类型数组;
2.测试点注意0以及和等于1000类型的情况,如果后面循环的判定用(sum!=0)就会出错,所以用(位数!=0)就可以了。
#include<stdio.h>
#include<math.h>
int main()
{
char cases[100];//习惯用cases保存输入
int tem,tempow;
int flag=0;
int sum=0,weishu=0;//位数不知道英文咋写,就写中文了QAQ
char a[10][5]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
scanf("%s",cases);
for(int i=0;cases[i]!='\0';i++)
sum+=cases[i]-'0';//char类型的数字转换成int,减去'0'就好啦
tem=sum;
while(tem){//其实吧可以用数组存储每一位然后倒着输出,但是考虑了一下,觉得直接算位数的时间复杂度比较低
weishu++;
tem/=10;
}
tem=sum;
while(weishu--){
tempow=pow(10,weishu);//pow运算比较耗时,所以用一个临时变量存储一下
if(flag) printf(" ");
flag=1;
printf("%s",a[tem/tempow]);
tem%=tempow;
}
if(flag==0) printf("ling");//输出a[0]的时间会比直接输出"ling"慢,所以直接输出"ling"
return 0;
}