读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
样例:">样例:">样例:">样例:">样例:">样例:">样例:">样例:">输入样例:
1234567890987654321123456789
输出样例:
yi san wu
解题思想:本题需要注意一点,输入样例不可以直接设置一个int变量来存储,数据太大了会溢出的,存放不下,应该用一个数组来存放输入的数据。然后设置一个拼音输出函数,很显然是使用switch语句,不同的数字对应不同的拼音,不要把这一步放在主函数里面,否则代码会很乱,不方便阅读。此时我们已经把数据存在数组里面了,然后只需要把数组里面的值全部加起来就和就行了,再把这个和的每位数字进行分解,存放在另一个数组里面。因为题目输出的是从百位,十位,个位依次输出的,所以先放在数组里面进行调换位置,不能直接模再除,这样顺序是反着的。最后题目的要求,行中最后一个拼音数字后没有空格,这个只需要做点小手段就好了,不是本题的难点所在,解析大概就是这样,其他请看代码部分。
#include<stdio.h>
#include<string.h>
void prif(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()
{
int n,ret;
int sum=0;
char num[100];
int a[10],i=0,j;
scanf("%s",num);//num[]存放输入数据
n=strlen(num);//求出输入数据的长度
j=n;
while(j>0)
{
//至于这里为什么要-'0',我查看了一下数组中存放的数据
//刚好每位数多了0的acii值
sum+=(num[j-1]-'0');
j--;
}
ret=sum;
//把求出的和的每位数字分解开,放入数组a中
while(ret!=0)
{
a[i]=ret%10;
ret/=10;
i++;
}
//由于后面的格式要求,所以先把第一个输出来,再后面按照空格输出
//其他的
prif(a[i-1]);
i--;
for(i-1;i>0;i--)
{
printf(" ");
prif(a[i-1]);
}
return 0;
}