读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
解题思路:
一开始解答本题时可能会采取使用int相关类型进行定义、获取输入,但由于本题的数据类型较大,这种方法并不能满足需求,我们可以使用字符串数组获取输入,随后通过ASCLL码值相减的方式将其转换成整数并求取各个位数和。最后输出时本人是将和的各个位拆开放到一个整型数组summ中,然后利用一开始就定义好的一个存放有各个数字的拼音的数组(其中拼音与数组下标相对应)正确输出。
代码:
#include <iostream>
using namespace std;
int main()
{
char n[10000]; // 用于获取输入
int i=0, len=0, sum=0, summ[100]; // len用于记录输出的位数, sum记录各个位数和, summ数组用于存放输出的结果
char s[10][5]= {"ling","yi","er","san","si","wu","liu","qi","ba","jiu"}; // 将各个位数的拼音存放在s数组中
while(cin>>n[i]) // 获取输入
{
sum += n[i] - '0'; // 计算各个位数和,由于输入的是字符,故将其与字符'0'的ASCLL码值相减,即可得到该字符的整数值
i++;
}
i=0;
while(sum) // 将位数和的结果拆分成单个数字存放在summ数组中并计算其长度,方便后续输出
{
summ[i] = sum % 10;
sum /= 10;
len++;
i++;
}
cout << s[summ[len-1]]; // 根据题目的输出格式要求,故将首个结果单独输出,其余输出前都加上一个空格
for(i=len-2; i>=0; i--)
{
cout << " " << s[summ[i]];
}
return 0;
}