输入一个整数(位数不超过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(void)
{
int n,i,m,j,e,h,c,g,z,y,l,k,f;
scanf("%d",&n);
i=0;
j=n;
if(n==0)
{
printf("a");
}
while(n>0)
{
n=n/10;
i++;
}
l=i;
for(i;i>0;i--)
{
e=0;
m=1;
for(k=i-1;k>0;k--)
{
m=m*10;
}
h=j/m;
j=j-h*m;
g=y=j;
switch(h){
case 0: printf("a"); break;
case 1: printf("b"); break;
case 2: printf("c"); break;
case 3: printf("d"); break;
case 4: printf("e"); break;
case 5: printf("f"); break;
case 6: printf("g"); break;
case 7: printf("h"); break;
case 8: printf("i"); break;
case 9: printf("j"); break;
}
switch(i){
case 2: printf("S"); break;
case 3: printf("B"); break;
case 4: printf("Q"); break;
case 5: printf("W"); break;
case 6: printf("S"); break;
case 7: printf("B"); break;
case 8: printf("Q"); break;
case 9: printf("Y"); break;
}
while(j>0)
{
j=j/10;
e++;
}
e=i-e-1;
if(l<9&&i>5&&e>2)
{
printf("W");
}
z=0;
while(g>0)
{
g=g/10;
z++;
}
c=0;
if(z!=0){
c=i-1-z;
}
else{
i=0;
}
if(c>3&&i>4||c==2&&i<4){
printf("a");
i=z+1;
}else if(c==2&&i>1){
printf("a");
i=i-2;
}else if(z<4&&c<9&&z!=0&&c!=1&&c!=0){
printf("a");
i=z+1;
}else if(c==1){
printf("a");
i=z+1;
}else{
i=z+1;
}
j=y;
}
return 0;
}
设计思路:
确认输入数的位数,利用for语句进行判断每个位置的数字是什么以及用switch语句来进行匹配相应的字母,通过得到的位数也可以利用for语句与switch语句来匹配相对应的拾、百、仟、万、亿,并在其中考虑特殊情况。还有考虑特殊情况输入数为零。
实验错误:
基本想法并没有出错但对于零的位置以及多少并没有更加深度考虑,没有考虑特殊情况。
运行截图:
流程图: