读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10^100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
AC代码:
#include <stdio.h>
#include <string.h>
int main(){
// long long int n;
// int sum=0;
// scanf("%lld",&n);
// while(n){
// sum=sum+n%10;
// n=n/10;
// }
//10^100已经大于long long int 的范围(10^64)了!
char num[101];//输入的数字 < 10^{100},即数字的位数 < 101
scanf("%s", num);
int sum = 0, len = strlen(num); //各位数字之和(易知<= 900);数字的位数
for (int i = 0; i < len; i++) {
sum += (num[i] - '0');
}
char *hashTable[10]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
//printf("%d",sum);
if(sum/100>0){
printf("%s ",hashTable[sum/100]);
}
if(sum/10>0){
printf("%s ",hashTable[sum/10%10]);
}
printf("%s",hashTable[sum%10]);
return 0;
}
注意的点
1、输入要求是一个自然数,且不超过101位,这个数已经大大超过了int、long之类的范围,只能通过char来定义了
2、如何把这一串字符单个还原成int类型进行加运算呢?可以直接ASCII码转换,比如用char字符‘1’减去48或者减去‘0’,这样我们就能得到整型的1。
3、关于用拼音表示,就要了解一下字符数组了QAQ,C语言的字符串数组,然后外面知道了,在C语言当中,*字符串数组可以使用: char a[] [10]; 或者 char a[]; 表示 。第一种表示方式固定了每个字符串的最大大小。第二种没有字符串的大小限制。
4、还有一个细节,100位就算全是9加起来也就900,10的3次方而已,因此在转换的时候就比较简单了,还有注意末尾没有空格。