题目 1002写出这个数
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10
100
。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
//代码如下
#include<stdio.h>
#include<string.h>
int main()
{
char num[101]; // 输入
int result[3]; //结果
char py[10][5]={"ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu"}; //定义中文
gets(num);
int sum=0,i,j=0;
for(i=0;i<strlen(num);i++)
{
sum+=num[i]-'0'; //注释1
}
while(sum)
{
result[j++]=sum%10; //注释2
sum/=10;
}
for(i=j-1;i>0;i--)
printf("%s ",py[result[i]]);
printf("%s",py[result[0]]);
return 0;
}
//*****************注释1:*****************************
/*
这是典型的字符串和数字转化的问题。
1虽然题干中写的是输入自然数n,但是在写代码的时候定义n为整型是不对的,因为把整型n的每一位相加,首先需要得到每一位的值,从数字中得到每一位,很麻烦。所以在写代码的时候应该直接定义n位char型的数组。遍历数组中的每一个字符,使用其ASCII运算,得到每一位相加的和。
for (int i = 0; i < strlen(num); i++)
{
sum = sum + num[i] - '0';
}
//***************注释2*****************************
/*
2.把得到的结果转化成拼音,以135为例。
先除10取余,得到最低位,然后再除10.
while (sum)
{
result[j++] = sum % 10;
sum = sum / 10;
}
result[0] = 135%10 = 5,n = 135/10 = 13,
result[1] = 13%10 = 3,n = 13/10 = 1,
result[2] = 1%10 = 1,n = 1/10 = 0,
*/
···