字符转数字!提取每位数字!STL栈!PAT乙级1002写出这个数(C++)

本文介绍了一种解决大数位数求和并将其转换为汉字输出的方法。通过使用字符串输入、ASCII码转化及栈存储技术,实现对任意大数的位数求和,并用汉语拼音形式展示结果,适用于超出常规数据类型限制的情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

只有代码的题解都是耍流氓!思路和解题要点才是题解的重点!


1002 写出这个数 (20 分)

读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。

输入格式:

每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10​100​​。

输出格式:

在一行内输出 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;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值