一、题目描述
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
二、思路分析
这题我认为比较考察字符串的一些东西,整个思路不是很难,把输入的一行数字累加起来,得到他们的和,最后用汉语拼音的方式写出来
三、代码以及提交截图
#include <iostream>
#include <string>
using namespace std;
int main()
{
string s; //将该数字以字符串的形式输入
cin >> s;
int sum = 0;
for(int i = 0; i < s.length(); i++)
{
sum = sum + (s[i] - '0');//通过i - '0'将每位字符型数字转换为整型数字,再计算累加和
}
string str[10] = {"ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu"};
string num = to_string(sum);//to_string将数字常量转换为字符串
for(int i = 0;i < num.length();i++)
{
if(i != 0)
{
cout << " ";
}
cout << str[num[i] - '0'];//很巧妙
}
return 0;
}
四、一些总结
1.to_string用法
具体可以看下这篇文章
std::to_string - cppreference.com
示例代码:
// CPP program to illustrate
// std::to_string
#include <bits/stdc++.h>
// Driver code
int main()
{
// Converting float to string
std::string str1 = std::to_string(12.10);
// Converting integer to string
std::string str2 = std::to_string(9999);
// Printing the strings
std::cout << str1 << '\n';
std::cout << str2 << '\n';
return 0;
}
输出结果:
12.100000
9999
2.s[i] - '0' 和 num[i] - '0'
注意到- '0',为什么要这样操作呢,显然结合题解代码,要把字符型数字转化为整型数字
举个例子,'9'=57 因为数字的ascii码是连续的所以'9'-'0'=57-48=9;
个人认为可以当作一个小技巧来记忆和使用
附上ASCII表