问题描述
输入一个整数(位数不超过9位)代表一个人民币值(单位为元),请转换成财务要求的大写中文格式。如23108元,转换后变成“贰万叁仟壹百零捌”元。为了简化输出,用小写英文字母a-j顺序代表大写数字0-9,用S、B、Q、W、Y分别代表拾、百、仟、万、亿。于是23108元应被转换输出为“cWdQbBai”元。
输入格式:
输入在一行中给出一个不超过9位的非负整数。
输出格式:
在一行中输出转换后的结果。注意“零”的用法必须符合中文习惯。
输入样例1:
813227345
输出样例1:
iYbQdBcScWhQdBeSf
输入样例2:
6900
输出样例2:
gQjB
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
解析
本题应着重注意数字“0”的问题。首先将一个数分成亿、万、千、百、十、个这几部分,应当注意从第一个不为0的部分开始读,不应该出现类似于0亿、0百万之类的开头。若某部分为0,且其后面的数整体不为0才可以将0读出来,并且如果连续两部分都为0,只能读一次。这里要注意“万”的部分与其他部分要区分,因为“万”包含了千万、百万、十万、一万这四个部分,读作几千几百几十几万(如果“万”之中的某部分为0,处理方式与后面的千百十个类似),若该部分为0,则不应当读末尾的万,将整体读作0即可。最后还应额外考虑数字0,读作0,不应该忽略。
具体的存储方式,仅需将0~9存入一个大小为10的字符数组即可。
代码
#include <iostream>
using namespace std;
int main()
{
int n;
cin>>n;
char num[10]={'a','b','c','d','e','f','g','h','i','j'};
int nn=n;
int yi=nn/100000000;nn-=yi*100000000;//亿
int wan=nn/10000;nn-=wan*10000;//万
int qian=nn/1000;nn-=qian*1000;//千
int bai=nn/100;nn-=bai*100;//百
int shi=nn/10;nn-=shi*10;//十
int ge=nn;//个
int tmp=wan;
int qianwan=tmp/1000;tmp-=qianwan*1000;//千万位
int baiwan=tmp/100;tmp-=baiwan*100;//百万位
int shiwan=tmp/10;tmp-=shiwan*10;//十万位
int yiwan=tmp;//万位
if(yi>0)//亿位不为0
cout<<num[yi]<<'Y';
if(wan!=0)//千万、百万、十万、万位不全为0
{
if(qianwan!=0)//千万位不为0
cout<<num[qianwan]<<"Q";
else if(yi!=0&&n%1000000!=0)cout<<num[0];
if(baiwan!=0)//百万位不为0
cout<<num[baiwan]<<"B";
else if(qianwan!=0&&n%100000!=0)cout<<num[0];
if(shiwan!=0)//十万位不为0
cout<<num[shiwan]<<"S";
else if(qianwan!=0&&baiwan!=0&&n%10000!=0) cout<<num[0];
if(yiwan!=0) cout<<num[yiwan];//万位不为0
cout<<"W";
}
else if(yi!=0&&n%1000!=0) cout<<num[0];
if(qian!=0)//千位不为0
cout<<num[qian]<<"Q";
else
if(wan!=0&&n%100!=0) cout<<num[0];
if(bai!=0)//百位不为0
cout<<num[bai]<<"B";
else
if(qian!=0&&n%10!=0) cout<<num[0];
if(shi!=0)//十位不为0
cout<<num[shi]<<"S";
else
if(bai!=0&&ge!=0) cout<<num[0];
if(ge!=0) cout<<num[ge];//个位不为0
if(n==0) cout<<num[0];
return 0;
}