输入一个整数(位数不超过9位)代表一个人民币值(单位为元),请转换成财务要求的大写中文格式。如23108元,转换后变成“贰万叁仟壹百零捌”元。为了简化输出,用小写英文字母a-j顺序代表大写数字0-9,用S、B、Q、W、Y分别代表拾、百、仟、万、亿。于是23108元应被转换输出为“cWdQbBai”元。
输入格式:
输入在一行中给出一个不超过9位的非负整数。
输出格式:
在一行中输出转换后的结果。注意“零”的用法必须符合中文习惯。
输入样例1:
813227345
输出样例1:
iYbQdBcScWhQdBeSf
输入样例2:
6900
输出样例2:
gQjB
思路:
- 定义三个字符串(数字,单位,结果)。
- 如果为0,直接输出,结束。
- (非0情况)得到数字串的最后一位。
- 最后一位非0,不是个位,存单位,是不是个位都存数字。
- 最后一位为0,是万位,存单位,不是万位,判断前一位是不是0,或者是不是个位,如果都不是,存0。
提交代码:
#include<stdio.h>
int main()
{
char num[10] = {'a','b','c','d','e','f','g','h','i','j'};
char unit[8] = {'S','B','Q','W','S','B','Q','Y'};
char res[17];
int n,cur,i = 0,j = 0,k,pre;
scanf("%d",&n);
if(!n)
printf("a");
else
{
while(n)
{
cur = n % 10;
n /= 10;
i ++;
if(cur)
{
if(i > 1)
{
res[j ++] = unit[i - 2];
}
res[j ++] = num[cur];
}
else
{
if(i == 5)
res[j ++] = unit[i - 2];
else if(pre!=0&&i!=1)
res[j++]=num[cur];
}
pre = cur;
}
for(k = j-1; k >= 0; k--)
printf("%c",res[k]);
}
return 0;
}