币值转换
输入一个整数(位数不超过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<string.h>
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;
}
正确实验截图:
错误实验代码:
#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; }
这个题之前我是想用switch编写的,但是编写过后发现中间的0没办法控制输出,然后在网上看到一个大佬用数组的方法做方便很多,然后就借鉴了这个大佬的做法,希望有哪个大佬能帮我修改修我的代码
输入一个整数(位数不超过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<string.h>
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;
}
正确实验截图:
错误实验代码:
#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; }
这个题之前我是想用switch编写的,但是编写过后发现中间的0没办法控制输出,然后在网上看到一个大佬用数组的方法做方便很多,然后就借鉴了这个大佬的做法,希望有哪个大佬能帮我修改修我的代码