如题
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10的100次方。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
思路
可以看出这里输入的数值可以是非常大的,最大不超过10的100次方,所以关键的一步是用字符串来存储数字,再把字符串处理一下,转换成数字之后相加。
程序
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
void ChinesePinyin(int n){
switch(n){
case 0: printf("ling");break;
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;
}
}
void ReadNum(int num){
if(num < 10){
ChinesePinyin(num);
}
else if(num < 100){
ChinesePinyin(num/10);
printf(" ");
ChinesePinyin(num%10);
}
else if(num <1000){
ChinesePinyin(num/100);
printf(" ");
ChinesePinyin(num/10%10);
printf(" ");
ChinesePinyin(num%10);
}
else if(num < 10000){
ChinesePinyin(num/1000);
printf(" ");
ChinesePinyin(num/100%10);
printf(" ");
ChinesePinyin(num/10%10);
printf(" ");
ChinesePinyin(num%10);
}
}
int main()
{
char str[100];
int sum = 0;
int num;
scanf("%s",str); //因为数字太大所以用字符串接收,对字符串进行转化
for(int i = 0;str[i] != '\0';i++){
num = str[i] - '0'; //把位数由字符转化为整数型
sum += num;
}
ReadNum(sum);
return 0;
}