题目:
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10^100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
思路:
首先看样例输入是给了一串很长的数,而且是先整体输入再统一输出,而不是即时输入即时存储判断的类型。那么这种情况下double,long,long long这种基本的数据类型是都不能使用的,所以数学方面的思路就到此为止了。接下来想的是用其它类型的方式去存储这一大长串数字,那么自然而然地想到了用string字符串类型,因为它的优点就是能存储很长的字符串而不担心溢出(一般情况下)。
之后就是要计算每个位置上的字符所对应实际数字的值(坑!)进行加和了。这里用到字符串遍历,那么久需要求字符串长度,要用到length()或者是size()函数,可以用for循环进行遍历,注意是从0开始计数的,并且注意length()的返回值是unsigned int类型(当然你写int vs2019不会报错,只会warning)现在解释上文的“坑”,即:在string类型中,你输入并且存储进去的都是以字符,就是ASCII码的形式存储进去的,而不是真正存储的这个数字本身。比如说
a="123";//a[0]='1'
int num=a[0];
cout<<num;
这段程序输出的结果是49,即1对应的ASCII码值。
因此如果想求得该位置所保存数字的真正的值,需要减去48,可以这样写:
int num=a[0]-'0';
//或:int num=a[0]-48;//'0'对应的ASCII码值是48
在遍历的时候同步进行累加,int count+=就可以了。
之后我们就得到了各个位数字的加和count,此时的问题是:如何做到让各位数字都能对应它们拼音并输出呢?没学多少知识(是我)的话想到的就是先一顿操作得到个、十、百位,然后三个switch语句,是,这样没有错误,可是非常臃肿,基本上就是复制粘贴。无论是你写的还是给别人看还是上交都不简洁,你自己心里也别扭——当你有这种感觉的时候就考虑看答案,刷题的目的不是求过,是去学习更好的知识。
看题解发现有一个非常好用的函数:
to_string()
功能:将数值转化为字符串并返回对应的字符串。
eg:string num = to_string(sum);
这样我们就能用更简化的代码来达到取得一个数字每一位的目的了。
下一个问题就是:如何实现每一位都能对应一个拼音?switch当然可以——但是就又陷入了复制粘贴陷阱,联想到输出的是拼音格式->拼音这种一串英文字符一般用字符串string存储->好多string->建立一个string数组,按数字分别设置对应位置的拼音。
最后的输出,因为最后不输出空格,所以先写一点代码判断什么时候输出空格——只要不是和对应字符串的最后一位,就都先输出空格。之后输出对应数字在拼音字符串数组中所对应的拼音就可以了,记得减去'0'!
代码直接看柳婼给的题解就可以了,简洁明快!
也附上我冗长的代码,不建议学习,只是感觉别人和我上的不是一个大学,我学了之后就只能写出来这样的代码(汗
#include<iostream>
#include<string>
using namespace std;
int main()
{
string a;
cin >> a;
//把字符串拆成单个字符
int num=0;//加和器
//cout << num << endl;
for (unsigned int i = 0; i < a.length(); i++)
{
num += a[i]-'0';
// cout << num << " ";
// cout << a[i] << " ";
}
int bai=0, shi=0, ge=0;
//我觉得除了switch语句一定还有别的简便方法
if (num < 10)
{
switch(num)
{
case 1:cout << "yi" << endl; break;
case 2:cout << "er" << endl; break;
case 3:cout << "san" << endl; break;
case 4:cout << "si" << endl; break;
case 5:cout << "wu" << endl; break;
case 6:cout << "liu" << endl; break;
case 7:cout << "qi" << endl; break;
case 8:cout << "ba" << endl; break;
case 9:cout << "jiu" << endl; break;
case 0:cout << "ling" << endl; break;
}
}
else if (10 < num && num < 100)
{
shi = num / 10;
ge = num - shi * 10;
switch (shi)
{
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;
case 0:cout << "ling" ; break;
}
cout << " ";
switch (ge)
{
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;
case 0:cout << "ling"; break;
}
// cout << ge << endl;
}
else
{
bai = num / 100;
shi = (num - bai * 100) / 10;
ge = num - bai * 100 - shi * 10;
switch (bai)
{
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;
//case 0:cout << "ling"; break;
default: break;
}
//cout << bai << " ";
cout << " ";
switch (shi)
{
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;
case 0:cout << "ling"; break;
}
// cout << shi << " ";
cout << " ";
switch (ge)
{
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;
case 0:cout << "ling"; break;
}
//cout << ge << endl;
}
return 0;
}
—————————————————2021.8.29二刷———————————————————
用的就是柳婼的思路了
#include<iostream>
#include<iomanip>
#include<vector>
#include<set>
#include<list>
#include<deque>
#include<stack>
#include<unordered_map>
#include<cctype>
#include<map>
#include<string>
#include<algorithm>
#include<cmath>
using namespace std;
int main()
{
string s;
cin >> s;
int cnt = 0;
string str[10] = { "ling", "yi", "er", "san", "si", "wu", "liu", "qi",
"ba", "jiu" };
for (int i = 0; i < s.length(); i++)
{
cnt += s[i] - '0';
}
string num = to_string(cnt);
for (int i = 0; i < num.length(); i++)
{
cout << str[num[i]-'0'];
if (i != num.length() - 1)
{
cout << " ";
}
}
return 0;
}