币值转换

输入一个整数(位数不超过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>
int main()
{
	int n,initial_n;
	scanf("%d",&n);
	initial_n=n;       //保留初始值 
	
	char num[10]={'a','b','c','d','e','f','g','h','i','j'};
	char unit[10]={0,0,'S','B','Q','W','S','B','Q','Y'};    //舍弃前两位 
	char result[17]={0};      //9位数最多有17位输出
	 
	int i,last_i=n%10;
	int j=0;
	int count_n=0;
	while(n>0){
		
		i=n%10;
		n/=10;
		count_n++;
		if(i==0&&(count_n%4)>1){      //从十位开始统计(个位 0 永远不输出 ) 
			if(last_i!=0){       //如果前一位不等于 0 ,那就输出这个 0 
				result[j++]=num[i];
			}
		}
		if(count_n==5&&i==0&&initial_n<100000000){
			result[j++]=unit[count_n];      //万 W 是一定要输出的 
		} 
		if(count_n>1&&i!=0){      //非 0 不输出单位 
			result[j++]=unit[count_n];
		}
		if(i!=0){      //处理非0数输出
			result[j++]=num[i];
		}
		last_i=i;      //保留 i 前一位的值用于处理0 
	}
	
	if(initial_n==0){      //处理特殊值 0 
		result[j++]=num[i];
	}
	
	for(j=j-1;j>=0;j--){
		printf("%c",result[j]);
	}
	
    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没办法控制输出,然后在网上看到一个大佬用数组的方法做方便很多,然后就借鉴了这个大佬的做法,希望有哪个大佬能帮我修改修我的代码

posted @ 2019-01-18 17:06  Mozzie邱治文  阅读(441)  评论(1编辑  收藏  举报