题目描述:
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10^100
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
思路:n的取值范围应该是给错了。。。感觉应该最多不过1000这个数量级的样子。思路就是用字符串读入n,再通过转义将字符变成数字,累加起来。然后分解得到总和的每个位置上的数,储存到一个数组里,由于是用个位数开始储存的,所以最后输出的时候要从数组的最后一位逆序输出。至于把数字输出成拼音,我一开始定义了一个函数,用到了swtich选择结构,但我的小伙伴看了之后嗤之以鼻,说换成数组储存运行起来的结果会更快。。。感兴趣的小伙伴可以试一试
解题代码:
#include <stdio.h>
void printHanzi(int n){
switch(n){
case 1:
printf("yi");
break;
case 2:
printf("er");
break;
case 3:
printf("san");
break;
case 4:
printf("si");
break;
case 5:
printf("wu");
break;
case 6:
printf("liu");
break;
case 7:
printf("qi");
break;
case 8:
printf("ba");
break;
case 9:
printf("jiu");
break;
case 0:
printf("ling");
break;
}
}
int main()
{
long long sum=0;
char str[110]; //接受输入的n
scanf("%s",str);
char *pstr=str;
while(*pstr){ //获取n的每一个字符,转成数字
char c=*pstr++;
sum+=(int)(c-'0'); //加到总和上
}
int nums[100]={0}; //储存总和的每一位数
int cnt=0;
while(sum){
int t=sum%10; //取最后一位数
sum/=10; //去掉最后一位数
nums[cnt++]=t;
}
for(int i=cnt-1;i>=0;i--){ //逆序输出
printHanzi(nums[i]);
if(i>0)
printf(" ");
}
return 0;
}