标签:人民币 必须 scanf case tin code 数组 string ase
币值转换
输入一个整数(位数不超过9位)代表一个人民币值(单位为元),请转换成财务要求的大写中文格式。如23108元,转换后变成“贰万叁仟壹百零捌”元。为了简化输出,用小写英文字母a-j顺序代表大写数字0-9,用S、B、Q、W、Y分别代表拾、百、仟、万、亿。于是23108元应被转换输出为“cWdQbBai”元。
输入格式:
输入在一行中给出一个不超过9位的非负整数。
输出格式:
在一行中输出转换后的结果。注意“零”的用法必须符合中文习惯。
输入样例1:
813227345
输出样例1:
iYbQdBcScWhQdBeSf
输入样例2:
6900
输出样例2:
gQjB
正确实验代码:
int main()
{
char a[10]={‘a‘,‘b‘,‘c‘,‘d‘,‘e‘,‘f‘,‘g‘,‘h‘,‘i‘,‘j‘};
char b[]={‘ ‘,‘ ‘,‘S‘,‘B‘,‘Q‘,‘W‘,‘S‘,‘B‘,‘Q‘,‘Y‘};
char num[10];
gets(num);
int l=strlen(num);
int n;
int i=0;
int ling=0;
int k=0;
if(num[0]==‘0‘&&l==1) printf("a"); //0的情况,但测试点不包含这个
else
while(l-->0)
{
n=num[i++]-‘0‘;
if(n!=0)
{
if(ling==1)
printf("a");
printf("%c",a[n]);
ling=0;
}
else
{
ling=1;
if(l==4&&k==1) printf("W");
continue;
} //按照中文习惯,四位数一段规律,再考虑万怎么处理
if(l>0)
{
if(l>4&&l<8) k=1;
printf("%c",b[l+1]);
}
}
return 0;
}
正确实验截图:
错误实验代码:
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;
}
这个题之前我不是这样编写的,但是后来发现中间有一些错误的方法,然后去网上看到一个用数组的方法做方便很多,然后就借鉴了这个做法
标签:人民币 必须 scanf case tin code 数组 string ase
原文地址:https://www.cnblogs.com/LJL555/p/10389837.html