7-1 币值转换 (20 分)
输入一个整数(位数不超过9位)代表一个人民币值(单位为元),请转换成财务要求的大写中文格式。如23108元,转换后变成“贰万叁仟壹百零捌”元。为了简化输出,用小写英文字母a-j顺序代表大写数字0-9,用S、B、Q、W、Y分别代表拾、百、仟、万、亿。于是23108元应被转换输出为“cWdQbBai”元。
输入格式:
输入在一行中给出一个不超过9位的非负整数。
输出格式:
在一行中输出转换后的结果。注意“零”的用法必须符合中文习惯。
输入样例1:
813227345
输出样例1:
iYbQdBcScWhQdBeSf
输入样例2:
6900
输出样例2:
gQjB
1).实验代码
#include<stdio.h>
int main()
{
int n,i,j;
char a[10]={'a','b','c','d','e','f','g','h','i','j'};
char b[10];
int c[10]={0,0,0,0,0,0,0,0,0,0};/*定义变量*/
scanf("%d",&n);
if
for(i=1;n>0;i++)
{
b[i]=n%10;
n=n/10;
}
i=i-1;
for(j=i;j>0;j--)
{
if(b[j]==0)
{
if(b[j-1]!=0)
printf("a");
}
else(n==0)
printf("a");/*单独讨论0*/
else
printf("%c",a[b[j]]);
printf("W");
if(b[j]!=0)
{
if(j==2&&j==6)
printf("S");
if(j==3&&j==7)
printf("B");
if(j==4&&j==8)
printf("Q");
if(j==9)
printf("Y");/*输出*/
}
}
}
return 0;
}
2) 设计思路
流程图:
先进行0的判读,在继续判断之后的数字,进行转化。
3)本题调试过程碰到问题及解决办法
问题:
#include<stdio.h>
int main()
{
int n;
scanf("%d",&n);
int i=100000000,j,k=8;
if(n==0){
printf("a",n);
}
while(n>0){
j=n/i;
if(j!=0){
break;
}
i=i/10;
k--;
}
char sum[9]={0,'S','B','Q','W','S','B','Q','Y'};
for(;n>0;k--){
j=n/i;
switch(j){
case 0:printf("a",j);break;
case 1:printf("b",j);break;
case 2:printf("c",j);break;
case 3:printf("d",j);break;
case 4:printf("e",j);break;
case 5:printf("f",j);break;
case 6:printf("g",j);break;
case 7:printf("h",j);break;
case 8:printf("i",j);break;
case 9:printf("j",j);break;
}
if(j!=0){
printf("%c",sum[k]);
}
n=n-j*i;
i=i/10;
}
return 0;
}
没有考虑0的情况
解决:参考同学,寻求办法。
4).运行结果截图