题目:
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10^100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
题目分析:
注意点:
1.n的范围超过了整数,所以可以使用字符数组存储测试用例。另外,对于牵扯处理"每一位或某些位"的题目,都可以选择使用字符数组存储测试用例。
2.因为使用字符串存储,则在加和时需要进行字符-数字转化:例‘1’-‘0’=1;
(拓展:字符串-数字转化可以用num=atoi(str)转化,其中num为转化后的数值,str为待转化的字符串)
3.数组存储时高阶位存储数字的低位,所以输出时采用逆向输出
提示:sz3[sz2[j-1]];这种查找方法建议掌握,十分高效,之后的题目中会经常遇到
4.控制空格常见方法:
第一种:前导空格,即先输入一个数据不加空格,之后每个数据都在前面加一个空格。
第二种:预先记录输出数据的数量,然后在输出时控制,即每输出一个数据,输出一个空格,最后一个数据之后不输出空格(较常用)
#include<stdio.h>
#define N 110
char sz3[10][5]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};//数字对应读音
int main()
{
int i,j=0,sum=0,sz2[4]={0};//sum为最终加和,sz2为加和值的每一位数字
char sz[N];//测试用例
scanf("%s",sz);
for(i=0;sz[i]!='\0';i++)
sum+=sz[i]-'0';//字符-数字转化
while(sum!=0)
{
sz2[j++]=sum%10;//存储每一位上的数值
sum/=10;
}
printf("%s",sz3[sz2[j-1]]);//输出最高位
for(i=j-2;i>=0;i--)//逆向输出
printf(" %s",sz3[sz2[i]]);//这里使用了前导空格的方法控制空格
printf("\n");
return 0;
}