读入一个正整数?n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
每个测试输入包含 1 个测试用例,即给出自然数?n?的值。这里保证?n?小于?10100。
在一行内输出?n?的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
1234567890987654321123456789
yi san wu
?下面是我的代码:
#include <bits/stdc++.h> //万能头
using namespace std;
string s; //输入
int sum = 0; //计算和
string ans; //存放整型和转化后的字符串
string a[10] = {"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
int main()
{
cin >> s;
for (int i = 0; i < s.size(); i++) {
sum += s[i]-'0'; //计算和
}
ans = to_string(sum); //to_string函数,将整型转化为字符串
for (int i = 0; i < ans.size(); i++) {
if (i) cout << " "; //排版
cout << a[ans[i]-'0']; //遍历字符串,将对应位置的字符转化为整型,然后对应a数组输出
}
}