问题描述:
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
程序代码:
#include<iostream>
#include<string>
using namespace std;
int main() {
string word;//用来表示正整数n。
cin >> word;
int sum = 0;
/*求和*/
for (auto c : word) {//使用auto自动识别类型,然后自动开始迭代,自动结束。c表示字符串word中的一个字符
sum = sum+c-'0';//将字符型转换为整型,然后进行求和。字符‘0’代表ASCII的数字值为48。
}
int a[10];//用来分开存放求和结果sum中的每一位数字,由于n<10^100,即sum<10^10。
int m = 0;//m用来表示求和结果sum的位数
for (int i =0; sum> 0; i++) {
a[i] = sum % 10;//将结果的每一位依次存入数组a[i]
sum = sum / 10;
m++;
}
string arr[10] = { "ling","yi","er","san","si","wu","liu","qi","ba","jiu" };
/*数字与字符串一一对应,然后输出*/
for (int i = m-1; i>=0; i--) {
cout << arr[a[i]];
if (i == 0) {//判断一下,结果的最后一个数字对应的字符串后面不需要输出空格
break;
}
else {
cout << " ";
}
}
return 0;
}