zoukankan      html  css  js  c++  java
  • 币值转换

    输入一个整数(位数不超过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没办法控制输出,然后在网上看到一个大佬用数组的方法做方便很多,然后就借鉴了这个大佬的做法,希望有哪个大佬能帮我修改修我的代码

  • 相关阅读:
    计蒜客 奇怪的国家
    计蒜客 泥塑课
    计蒜客 判断质数
    hiho #1143 : 骨牌覆盖问题·一 (运用快速幂矩阵)
    二叉树建立,先序、中序、后序遍历(c实现)
    hiho #1272 买零食 [Offer收割]编程练习赛2
    hiho #1283 hiho密码 [Offer收割]编程练习赛3
    hiho #1288 微软2016.4校招笔试题 Font Size
    hiho一下 第九十八周 搜索一·24点
    hiho一下 第九十七周 数论六·模线性方程组
  • 原文地址:https://www.cnblogs.com/mozzieqzw/p/10288670.html
Copyright © 2011-2022 走看看