1002 写出这个数 (20 分)

本博客介绍了一个算法,用于读取一个大整数并计算其各位数字之和,然后将该和的每位数字转换成汉语拼音。通过使用栈和向量,程序能够高效地处理大数并进行拼音输出。

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

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

输入格式:

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

输出格式:

在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。

输入样例:

1234567890987654321123456789

输出样例:

yi san wu
#include <iostream>
#include <vector>
#include <stack>
using namespace std;
vector<vector<string> > q;
stack<int> p;
int main() {
	q.clear();
	q.resize(1e6);
	string s;
	cin >> s;
	int n = s.size();
	int sum = 0;
	for (int i = 0; i < n; i++) {
		sum += s[i] - '0';
	}
	q[0].push_back("ling");
	q[1].push_back("yi");
	q[2].push_back("er");
	q[3].push_back("san");
	q[4].push_back("si");
	q[5].push_back("wu");
	q[6].push_back("liu");
	q[7].push_back("qi");
	q[8].push_back("ba");
	q[9].push_back("jiu");
	while (sum) {
		p.push(sum % 10);
		sum = sum / 10;
	}
	int m = 0;
	while (p.empty() == 0) {
		m++;
		int x = p.top();
		p.pop();
		if (m == 1)
			cout << q[x][0];
		else
			cout << ' ' << q[x][0];
	}
	cout << endl;
	return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值