题目
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
123456789123456789123456789
输出样例:
yi san wu
代码
#include <iostream>
#include <sstream>
#include <string>
using namespace std;
int main()
{
//计算所给字符串的数字加和
string temp;
string table[] = { "ling","yi","er","san","si","wu","liu","qi","ba","jiu" };
cin >> temp;
int sum = 0;
for (int i = 0; i < temp.size(); i++)
{
sum += temp[i] - '0';
}
//以下开始将数字转换为字符串
stringstream ss;
ss << sum;
ss >> temp;
//输出
for (int i = 0; i < temp.size(); i++)
{
if (i == temp.size() - 1)
cout << table[temp[i] - '0'];
else
cout << table[temp[i] - '0'] << " ";
}
return 0;
}
小总结
string本身可以当作一个存放char类型数据的数组,可以直接计算加和;得到加和之后,有两种方式继续处理,一种是当成数字,逐个提取,换算成拼音,不过需要递归,一种是当作字符串,其他文章大多是用的前者,我就写了一下用字符串的咯