读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
yi san wu
解题思路:
用字符串读入数字,将对于字符转换为相应数字相加,再把总和的每个数字用数组存起来,根据数字输出相应的中文。
#include <cstdio>
#include <cstring>
const int maxn = 105; //定义maxn为105,稍大于100
int main() {
char num[maxn];
char numToChinese[10][5] = {"ling", "yi", "er", "san", "si", "wu", "liu", "qi",
"ba", "jiu"};
int res[3];
int sum = 0, cnt = 0;
scanf("%s", num);
int len = strlen(num); //字符串的长度
for(int i = 0; i < len; i++) {
sum = sum + (num[i] - '0'); //数字总和
}
if(sum == 0) printf("ling"); //如果和为0,直接输出
else {
while(sum != 0) { //将sum各个位数上的数字存在res数组
res[cnt] = sum % 10;
sum /= 10;
cnt++;
}
}
for(int i = cnt - 1; i >= 0; i--) { //根据数字输出相应的中文
printf("%s", numToChinese[res[i]]);
if(i != 0) printf(" ");
}
return 0;
}