输入一个整数(位数不超过9位)代表一个人民币值(单位为元),请转换成财务要求的大写中文格式。如23108元,转换后变成“贰万叁仟壹百零捌”元。为了简化输出,用小写英文字母a-j顺序代表大写数字0-9,用S、B、Q、W、Y分别代表拾、百、仟、万、亿。于是23108元应被转换输出为“cWdQbBai”元。
输入格式:
输入在一行中给出一个不超过9位的非负整数。
输出格式:
在一行中输出转换后的结果。注意“零”的用法必须符合中文习惯。# 输入样例1:
输入样例1:
813227345
输出样例1:
iYbQdBcScWhQdBeSf
输入样例2:
6900
输出样例2:
gQjB
最好一开始用字符串存储这个数字,然后从从个位往高位进行遍历,首先判断个位到高位有几个0,然后从第一个不为0的位置继续往最高位进行遍历,最后找到相应答案并输出。

#include<bits/stdc++.h>
using namespace std;
char num[10]={'a','b','c','d','e','f','g','h','i','j'};
char sign[9]={'e','S','B','Q','W','S','B','Q','Y'};
int main()
{
string s,ans;
cin>>s;
if(s=="0") cout<<"a"<<endl;
else{
int co=s.size()-1,bit=0,f=0;
while(s[co]=='0') //判断最低位是否为0,把尾部的0全部都去掉
{
bit++;
co--;
}
for(int i=co;i>=0;i--)
{
if(s[i]=='0')
{
f=1;
bit++;
}
else if(s[i]!='0')
{
if(f==1)
{
if(bit>4) ans = ans + num[0] + 'W';
else ans = ans + num[0];
ans = ans + sign[bit];
ans = ans + num[s[i]-'0'];
f=0;
}
else{
if(bit!=0) ans = ans + sign[bit];
ans = ans + num[s[i]-'0'];
}
bit++;
}
}
cout<<string(ans.rbegin(),ans.rend());
}
return 0;
}
本文介绍了一种将整数转换为中文大写金额的方法,适用于财务场景。通过使用特定字符代表大写数字和单位,实现了从个位到亿位的遍历转换,确保了‘零’的正确使用。
3210

被折叠的 条评论
为什么被折叠?



