输入一个整数(位数不超过9位)代表一个人民币值(单位为元),请转换成财务要求的大写中文格式。如23108元,转换后变成“贰万叁仟壹百零捌”元。为了简化输出,用小写英文字母a-j顺序代表大写数字0-9,用S、B、Q、W、Y分别代表拾、百、仟、万、亿。于是23108元应被转换输出为“cWdQbBai”元。
输入格式:
输入在一行中给出一个不超过9位的非负整数。
输出格式:
在一行中输出转换后的结果。注意“零”的用法必须符合中文习惯。
代码:
#include<stdio.h>
int main(){
/* */
int m,flag1=0,flag2=-1;
/*
举个例子:3600存储在下面这个很丑的数组中
下标:0 1 2 3 4 5 6 7 8
单位:亿 千万 百万 十万 万 千 百 十 个
值 :0 0 0 0 0 3 6 0 0
*/
//flag1用于标记输入数据的最高位所在数组的位置(后面会把输入的数字拆开每一位存入数组,
//如果数值比较小,前面就会有很多零,因此要找到第一个不为零的位置从这里开始输出)
//flag2用于标记最后一个非零数字位置(如3600读作三千六百,后面的两个零是不输出的)
char u1[10]={'a','b','c','d','e','f','g','h','i','j'};//存储0-9代表的字母
scanf("%d",&m);
//如果输入值为0,直接输出0并退出程序即可;
if(m==0){
printf("a");
exit(0);
}
int a[9]={0};//定义一个上面画的数组
char u2[8]={'Y','Q','B','S','W','Q','B','S'};//把单位存下来
//获取各位数字并存到数组中(这步操作很多题目都会用到,要熟练!)
for(int i=8;i>=0;i--){
a[i]=m%10;
m/=10;
}
//寻找最后一个非零数字位置
for(int j=0;j<9;j++){
if(a[j]==0) flag2=j-1;
else flag2=-1;
}
for(int i=0;i<9;i++){
//遍历到最后一个非零位置直接退出循环
if(i==flag2) {
break;
}
//找到第一个不为零的位置,flag变为1,此后就一直是1;
if(a[i]!=0) flag1=1;
//情况一:该位置数字≠0,这种最简单,直接输出对应字母
if(flag1==1){
if(a[i]!=0){
printf("%c",u1[a[i]]);
}
//情况二:对于该位置数字=0,要继续分多种情况讨论
else if(a[i]==0){
//情况(1)中间单个0
if(a[i-1]!=0&&a[i+1]!=0){//如101这种情况
printf("a");
continue;//此处continue的原因是不能出现一百零十一,零是没有单位的
}
//情况(2)中间有多个零,如10086,
else if(a[i-1]==0&&a[i+1]!=0){ printf("a");}//判断当前位置是否为中间的最后一个零,只需输出最后一个零即可
//情况(3)中间有多个零但零和它前面的数字组成整体,如100000十万,第一个零后带有单位万
else {
if(a[i-1]!=0){printf("%c",u2[i]);}//输出数字对应单位
}
}
//最后正常输出单位即可,注意最后一个数字无单位,因此不能输出u2[8];
if(i<8&&a[i]!=0){
printf("%c",u2[i]);
}
}
}
return 0;
}
把握住问题其实就两部分:一、输出各位数字 二、在数字后输出单位,用两个数组分别存数字和单位,碰到正常数字就输出,碰到零就分几种情况分别输出就好了,难就难在零的情况比较多且不好处理,上一题兔子睡觉一上午才搞出来,这题又直接一下午呜呜呜呜呜,比赛如果出这题,我怕是要直接放弃。。。(自己练决不放弃,哪怕死扣一星期!)
注意几点:
1.会拆分数字
2.熟练运用flag判断各种情况
3.格式要整洁,大括号对齐点,不然if-else 多了看的脑瓜子并疼怀疑人生
4.几种特殊情况的处理,如10086的0只输出一次且不能有单位;100001的第一个零后要输出单位