1002 写出这个数
一、题目
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
二、输入输出
输入格式
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 1 0 100 10^{100} 10100。
输出格式
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
三、样例
输入样例
1234567890987654321123456789
输出样例
yi san wu
四、题目分析
这是一道字符串处理题,采用模拟的方法,按照题目要求,将每一位相加后,转化为字符串,根据字符串的每一个字符选择输出拼音。
五、代码
#include <bits/stdc++.h>
using namespace std;
int main()
{
int sum = 0;
string s, ss;
cin >> s;
for (int i = 0; i < s.length(); i++)
{
sum += s[i] - '0';
}
ss = to_string(sum);
for (int i = 0; i < ss.length(); i++)
{
if (i)
{
cout << " ";
}
switch (ss[i] - '0')
{
case 0:
cout << "ling";
break;
case 1:
cout << "yi";
break;
case 2:
cout << "er";
break;
case 3:
cout << "san";
break;
case 4:
cout << "si";
break;
case 5:
cout << "wu";
break;
case 6:
cout << "liu";
break;
case 7:
cout << "qi";
break;
case 8:
cout << "ba";
break;
case 9:
cout << "jiu";
break;
}
}
return 0;
}
六、总结
-
(1)代码采取先读入,后求和处理的方法。可以改进为读入字符的同时计数求和,减少了时间复杂度。由于题目是输入小于100个字符,因此不会超时。
-
(2)整数转化为字符串的方法:
将整数value转化为字符串s
std::string s = std::to_string(value) ;
-
最后不输出空格/换行的方法:
有时题目在每个输出之间有空格或者换行连接,但是最后一个输出没有空格或换行,在有的平台不会对最后一个空字符检测,但以防万一,采用以下方法:对第 i i i 次输出,当 i = 0 i=0 i=0 是不输出空格或换行符,否则先输出空格或换行符,再输出内容。
for (int i = 0; i < ss.length(); i++) { if (i) cout << "/*链接字符*/"; cout <<"/*每个答案*/"; }