只有代码的题解都是耍流氓!思路和解题要点才是题解的重点!
1002 写出这个数 (20 分)
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
思路解析:
这题其实是一道简单题,但是涉及了数组枚举、 数字和字符的转化、提取数字中的每一位,我还用了栈来记录数字。我觉得这几个才是这道题的解题意义所在。思路很简单:用数组记录下每个数字的汉字拼音,输入数字太大,所以需要用字符串输入。这也是解题的小技巧,因为很多时候往往数字大到long long int、int_64都装不下,这时需要用字符串记录。而字符串和数字的转化其实是基于ASCII码的,很简单,加‘0’、减‘0’即可,字母和数字的转化同理是通过‘a’或'0'完成。而提取每一位数字则是通过不断地%10,再用栈来存储,这样就可以完成数字的逆序!思路解析和代码一起服用效果更佳哦!
代码:
#include <iostream>
#include <string>
#include <cmath>
#include <stack>
#include <algorithm>
using namespace std;
int main()
{
string s[12];
stack<int> a;
int i, c, t, k;
string n;
s[0] = "ling";s[1] = "yi";s[2] = "er";s[3] = "san";s[4] = "si";s[5] = "wu";s[6] = "liu";s[7] = "qi";s[8] = "ba";s[9] = "jiu";
while (cin >> n)
{
c = 0;
k = n.size();
for (i = 0;i<k;i++)
{
c += n[i] - '0';
}
t = c;
while (t != 0)
{
k = t % 10;
a.push(k);
t = t / 10;
}
cout << s[a.top()];
a.pop();
while (!a.empty())
{
cout << " " << s[a.top()];
a.pop();
}
cout << endl;
}
return 0;
}