输入一个整数(位数不超过9位)代表一个人民币值(单位为元),请转换成财务要求的大写中文格式。如23108元,转换后变成“贰万叁仟壹百零捌”元。为了简化输出,用小写英文字母a-j顺序代表大写数字0-9,用S、B、Q、W、Y分别代表拾、百、仟、万、亿。于是23108元应被转换输出为“cWdQbBai”元。
输入格式:
输入在一行中给出一个不超过9位的非负整数。
输出格式:
在一行中输出转换后的结果。注意“零”的用法必须符合中文习惯。
输入样例1:
813227345
输出样例1:
iYbQdBcScWhQdBeSf
输入样例2:
6900
输出样例2:
gQjB
解法一:
#include <stdio.h>
int main()
{
int i=0,j,n;
scanf("%d",&n);
char a[9];
char b[9]={'\n','S','B','Q','W','S','B','Q','Y'}; //位的名称存入数组b
if(n==0){
printf("a\n");
} else{
while(n!=0){ //数字存入数组a
a[i]=n%10;
n=n/10;
i++;
}
i=i-1;
for(;i>=0;i--){ //数组a反向输出
if(a[i]==0){
if(i==4){ //万位为0的情况
if(a[8]!=0 && a[7]+a[6]+a[5]+a[4]==0 ){ //有亿位,且万位均为零
printf("a"); //输出一个零(如100004800)
}else{
printf("W"); //否侧万位就输出一个万。
}
}else{
if(a[i-1]==0){ //重复0不输出
continue;
}else{ // 一般的0就输出零,没有位的名称
printf("a");
}
}
}else{
printf("%c%c",a[i]+'a',b[i]);
}
}
}
return 0;
}
总结:
数字存在一个数组,位数名称存在一个数组。由大到小反向输出两个数组。
其他就是对于读数规则的判定。
解法二:
#include <stdio.h>
#include <string.h>
int main()
{
int i,n;
char a[15];
scanf("%s",&a);
char b[9]={'\n','S','B','Q','W','S','B','Q','Y'};
if(a[0]=='0') {printf("a\n"); return 0;}
n=strlen(a);
for(i=0;i<n;i++){
if(a[i]=='0'){
if(i==n-4) printf("W");
if(i<n-1&&a[i+1]=='0'||i==n-1)continue; //中文零的读法
else printf("a");
}else printf("%c%c",a[i]+'a'-'0',b[n-i-1]);
}
return 0;
}
把数按字符串输入(正向输入)