设定1000,0000范围以内,把阿拉伯数字转换为汉语数字

本文介绍了一种将阿拉伯数字形式的整数(不超过一万)转换为中文汉字数字表示的方法,通过分段处理和高位低位逻辑,提供了一个高效的字符串转换函数。代码示例详细展示了这个过程,并用于处理任意大小的一万以内数字。
摘要由CSDN通过智能技术生成


一十一
一百一十一
一千一百一十一
一千一百一十一
一十一一千一百一十一
一百一十一一千一百一十一
一千一百一十一一千一百一十一

可以发现每一千是一个单位。所以我们可以把多数分成多个一千去单独处理。中间再额外添加一个万即可。

所以就可以将问题转换成如何处理一个一万以内的数字的阿拉伯表示形式
分情况讨论可以发现。
1000 一千
1100 一千一百
1010 一千零一十
这也可以分成三个部分 高位 +零+低位
其中零和低位要么同时出现[1010]要么不出现[1100]
所以我们只需要先依次把高位遍历知道走到零就停
再将当前位置继续往后遍历,如果遇到非零则说明存在低位,否则没有低位。
存在低位就加一个”零“,再重复类似高位的操作作为低位。
不存在就直接结束。

代码:

#include <iostream>
#include <string>
using namespace std;
string bits[] = { "","十","百","千" };
string numberstr[] = { "","一","二","三","四","五","六","七","八","九" };
///拿到一万以内的数字【不包含一万】返回一个汉语数字
inline string GetNumber(const string number)
{
	//分成三段  
	/*
	如:1011 一千零一十一
	一千      零  一十一
	从最高位  零  低位
	但是低位可能为0
	如:1100
	一千一百
	*/
	//先处理高位
	int j = 0;
	string res = "";
	int size = number.size();
	while (j < size && number[j] != '0')
	{
		res += numberstr[number[j] - '0'] + bits[size - j - 1];
		j++;
	}

	while (j < size && number[j] == '0')
	{
		j++;
	}
	if (j < size)
	{
		res += "零";
		while (j < size && number[j] != '0')
		{
			res += numberstr[number[j] - '0'] + bits[size - j - 1];
			j++;
		}
	}
	return res;
}
inline void Work(const int num)
{
	if (num == 0)
	{
		cout << "零";
	}
	else
	{
		if (num >= 10000)
		{
			cout << GetNumber(to_string(num / 10000));
			cout << "万";
			cout << GetNumber(to_string(num % 10000));
		}
		else {

			cout << GetNumber(to_string(num % 10000));
		}
	}

	puts("");
}

int main() {
	int num = 10000000;
	while (num >=0)
	{
		Work(num);
		num--;
	}
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值