币值转换
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
include <stdio.h>
include <math.h>
int main()
{
int a,b,c,d,e,x,i,j,p,l,w;
scanf("%d",&l);
a=b=l;
if(a0){
printf("a");
}
for(i=0;a>0;i++){
a=a/10;
}
c=i;
for(i;i>0;i--){
x=1;
e=0;
for(p=i-1;m>0;p--){
x=x10;
}
a=b/x;
b=b-ax;
switch(a){
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;
}
j=0;
for(d=b;d>0;j++){
d=d/10;
}
j=i-j-1;
if(c<9&&i>5&&j>2){
printf("W");
}
j=0;
for(d=b;d>0;j++){
d=d/10;
}
if(j!=0){
e=i-j-1;
}else{
i=0;
}
if(e>3&&i>4||e2&&i<4){
printf("a");
i=j+1;
}else if(e2&&i>1){
printf("a");
i=i-2;
}else if(j<4&&c<9&&j!=0&&e!=1&&e!=0){
printf("a");
i=j+1;
}else if(e1){
printf("a");
i=j+1;
}else{
i=j+1;
}
}
return 0;
}
代码借鉴一位大佬的 博客园名字逍遥籽
设计思路
先定义整形变量,然后进行赋值,接着判断位数是否为零,如果是的话 就输出结果,
假如否的话,就判断这个位数是否能够整除一个亿,如果能,则从最大数开始递减,如若
不能,则判断位数是否为零,如若不是,则输出结果,假若判断位数为零,则判断该位数
的前一位为零的话就输出结果,运用if函数进行判断是否进行下面的循环,运用for语句进行循环。
运用switch语句进行输出判断,输出对于的字母,运用if和for语句进行判断。
运行截图