1002 写出这个数 C语言
读取一个正整数n,计算其各位数字之和,用汉语拼音输出和的每一位数字。
输入格式
每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10^100.
输出格式
在一行内输出n的各位数字之和的每一位,拼音数字间有1空格,但一行中最后一个拼音数字后没有空格。
输入样例
1234567890987654321123456789
输出样例
yi san wu
解答代码
#include<stdio.h>
int main(void) {
char s[10][5] = { "ling","yi","er","san","si","wu","liu","qi","ba","jiu" }; //用字符型二维数组存储数字对应的拼音
char input[105]; //数字过大,使用字符串存储。10的100次方应该为100位,这里稍大空间,保证数组不会越界。
int sum = 0, i = 0;
int n[5];//最大为3为数,同理稍微申请大一点空间,防止数组越界。
scanf("%s", input);
//按位读取数字,根据ASC II 码,字符的ASC II码-48即可得到对应的整数,这个循环用来求和
while (input[i]) {
sum += (int)input[i]-48;
i++;
}
//对sum值按位存入数组n中,反向存入
i = 0;
do{
n[i] = sum % 10;
sum /= 10;
i++;
} while (sum > 0);
//反向读取数组n中的值,并按照对应数字输出拼音
for (i = i - 1; i >= 0; i--) {
if (i == 0) {
printf("%s", s[n[i]]);
}
else {
printf("%s ", s[n[i]]);
}
}
return 0;
}
思路(小结)
- 10的100次方是个很大的数字,比C语言内置的任何数据类型(如double、long、long long等)都更大,因此必须使用字符串来存储数字。
- 对字符串根据ASC II码按位获取数值并求和。
- 对求和的数字再按位分解,存入数组中。
- 根据数组中的值,映射对应字符串,并进行输出。
- 要小心特殊情况,例如1234567895,和为50,输出为5则判定为错(使用辅助数组n解决);例如0,可能不输出(使用do-while解决)。