输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
首先定义一个容量为10的字符数组用来存储0-9的汉语拼音,然后将读入的字符串中的每个字符转换为数字然后求和,这里要对和为0进行特判,如果和为0,直接输出“ling”即可。由于需要从右往左进行输出,所以将sum的每一位转换为字符,每个数字所对应的即为,数组的下标,直接输出即可
#include <bits/stdc++.h>
using namespace std;
int main()
{
string s;
getline(cin,s);
string array[10] = {"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};//0-9的拼音
int sum = 0;
for(int i = 0 ; i < s.length() ; i++)
sum += (s[i]- '0');
if(sum == 0) //特判
{
cout << "ling";
return 0;
}
string str = "";
while(sum)
{
str += sum%10+'0';
sum /= 10;
}
reverse(str.begin(),str.end());
for(int i = 0 ; i < str.length() ; i++)
{
cout << array[str[i]-'0']; //每个数字对应的即为存储拼音数组的下标
if(i != str.length() - 1) //末尾不要输出多余的空格
cout << " ";
}
return 0;
}
提交截图: