7-3 币值转换

输入一个整数(位数不超过9位)代表一个人民币值(单位为元),请转换成财务要求的大写中文格式。如23108元,转换后变成“贰万叁仟壹百零捌”元。为了简化输出,用小写英文字母a-j顺序代表大写数字0-9,用S、B、Q、W、Y分别代表拾、百、仟、万、亿。于是23108元应被转换输出为“cWdQbBai”元。

输入格式:

输入在一行中给出一个不超过9位的非负整数。

输出格式:

在一行中输出转换后的结果。注意“零”的用法必须符合中文习惯。

输入样例1:

813227345

输出样例1:

iYbQdBcScWhQdBeSf

输入样例2:

6900

输出样例2:

gQjB

  思路讲解:

首先,我们需要先输入一个字符串型的数字,以便逐位处理,使用一个result来保存“大写中文形式”。

然后,我们需要定义一个对应关系,将数字 0 到 9 分别映射为对应的字母,例如 0 对应 "a",1 对应 "b",2 对应 "c",以此类推。

switch(num[i]){
		    case '0': if(i!=length-1)result+='a';break;
	     	case '1': result+='b';break;
			case '2': result+='c';break;
		    case '3': result+='d';break;
			case '4': result+='e';break;
			case '5': result+='f';break;
			case '6': result+='g';break;
			case '7': result+='h';break;
			case '8': result+='i';break;
			case '9': result+='j';break;
		}

 

我们还需要定义数字的位置对应的单位,例如个位对应 "元",十位对应 "拾",百位对应 "佰",千位对应 "仟",以此类推。

if(k==8) result+='Y';
		if(k==7) result+='Q';
		if(k==6) result+='B';
		if(k==5) result+='S';
		if(k==4) result+='W';
		if(k==3) result+='Q';
		if(k==2) result+='B';
		if(k==1) result+='S';

 

接下来,我们可以从字符串的最高位(左边第一位)开始逐个处理每一位数字。对于每一位数字,我们根据其值和位置进行转换,并将结果拼接起来。 

在处理连续的零时,我们需要根据位置添加对应的单位,例如 "零" 后面跟着 "万" 或者 "亿"。

if(num[i]=='0'&&num[i+1]=='0'){if(k==4) result+='W'; k--;continue;}

 

最后,我们需要注意处理特殊情况,例如当最高位是 0 时,需要输出 "零元"。

if(num[0]=='0'){printf("a");return 0;}

完整代码:

#include <bits/stdc++.h>
using namespace std;

int main()
{
	string num;
	cin>>num;
	int length=0;
	length=num.length();
	string result;
	int k=length-1;
	if(num[0]=='0'){printf("a");return 0;}
	for(int i=0;i<length;i++){
		if(num[i]=='0'&&num[i+1]=='0'){if(k==4) result+='W'; k--;continue;}
		switch(num[i]){
		    case '0': if(i!=length-1)result+='a';break;
	     	case '1': result+='b';break;
			case '2': result+='c';break;
		    case '3': result+='d';break;
			case '4': result+='e';break;
			case '5': result+='f';break;
			case '6': result+='g';break;
			case '7': result+='h';break;
			case '8': result+='i';break;
			case '9': result+='j';break;
		}
		if(num[i]!='0')
		{
		if(k==8) result+='Y';
		if(k==7) result+='Q';
		if(k==6) result+='B';
		if(k==5) result+='S';
		if(k==4) result+='W';
		if(k==3) result+='Q';
		if(k==2) result+='B';
		if(k==1) result+='S';
		}
		
		k--;
	}
	cout<<result;
	
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值