#include<iostream>
#include<vector>
#include<string>
using namespace std;
int main()
{
	string numbers;
	cin >> numbers;//把所有位上的数字都储存在字符串里头
	unsigned int sum = 0;
	for (auto a : numbers)
		sum = a + sum - 48;//sum计算所有位上的数字之和
	//注意减去四十八是因为零到九的数字的ASCII码比实际的都大48
	const vector<string> py{"ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu"};
	if (sum < 10)
	{
		cout << py[sum];
	}
	else if ((sum > 10) && (sum < 100))
	{
		cout << py[sum / 10] << " " << py[sum % 10];
	}
	else
		cout << py[sum / 100] << " " << py[(sum % 100) / 10]<<" "
		<< py[sum % 10];
	return 0;
}

分析思路:

1.第一时间想到高精度,用高精度实际上小题大做了。

2.观察到题目数据大小限制,估算出计算后的和不会超过999,

可以简单用if条件结构处理。

3.字符串可以与整型进行数据类型隐式转换。所以可以通过字符串寄存

数字后再通过遍历的方式求和。

回顾知识

1.string对象通过cin读入时候读到空格为止,且最后一个空格不被读入string内存。

2.零到九的数字ASCII码比原来的大48,所以代码中减去了48.

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐