• 7-1 币值转换 (20 分)


    7-1 币值转换 (20 分)

    输入一个整数(位数不超过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 (void)
    {
    	int n, value, value1, value2, sum=0, x, value3, qian=1000, y=0, jishuqi=0;
    	scanf("%d", &n);
    	value=n/100000000;
    	if(value!=0){
    		printf("%cY", 'a'+value);                      /*输出亿位*/
    	}
            value1=n%100000000;
    	value2=value1/10000;                                 /*得到万位数字*/
    	while(qian!=0){                                            /*输出万位*/
    		if(value2==0){
    			break;
    		}
    		x=value2/qian;
    		value2=value2%qian;
    		qian=qian/10;
    		y++;
    		if(value==0&&x==0){                
    			if(jishuqi!=1){
    				continue;
    			}
    		}
    		if(x==0){
    			sum++;
    			if(sum<=1) {
    				if(y!=4){
    					printf("%c", 'a');
    				}	
    			}
    		}
    		if(x!=0){
    			sum=0;
    			jishuqi=1;
    			printf("%c", 'a'+x);
    			switch(y){
    				case 1: printf("Q"); break;
    				case 2: printf("B"); break;
    				case 3: printf("S"); break;
    			}
    		}
    	}
    	if(y!=0){
    		printf("W");                                      /*输出万位结束*/
    	}
    	sum=0;                                                    /*输出千位以下需要重新赋初始值,因为在万位运算的时候值变化了*/
    	qian=1000;
    	y=0;
    	jishuqi=0;
    	value3=n%10000;                                    /*得到千以及以下数字*/
    	while(qian!=0){
    		x=value3/qian;
    		value3=value3%qian;
    		qian=qian/10;
    		y++;
    		if((n%100000000)/10000==0&&x==0){
    			if(jishuqi!=1){
    				continue;
    			}
    		}
    		if(value3!=0){
    			if(x==0){
    			    sum++;
    			    if(sum<=1) {
    				    printf("%c", 'a');
    			    }
    		    }
    		}
    		if(x!=0){
    			sum=0;
    			jishuqi=1;
    			printf("%c", 'a'+x);
    			switch(y){
    				case 1: printf("Q"); break;
    				case 2: printf("B"); break;
    				case 3: printf("S"); break;
    			}
    		}
    	}
            if(n==0){
    		printf("%c", 'a');
    	}	
    } 
    

    设计思路

    第一步:整体来看,把他们区分为三个区间,分别是亿,万,千以下
    第二步:输出亿位,这个很简单
    第三部:输出万位,这个考虑的就有很多,比如首位是零,还有连续的零,最后一个是零,下面一一讲解
    ********:第一:比如亿位为零且万位第一位位为零,那么这个零不能输出

    if(value==0&&x==0){
    			if(jishuqi!=1){
    				continue;
    			}
    		}
    

    ********:第二:万位中间有两个零,但按我们中文规则只能输出一个零,且没有“零百”,“零十”,而且最后一位为零不输出

                   if(x==0){
    			sum++;
    			if(sum<=1) {
    				if(y!=4){
    					printf("%c", 'a');
    				}	
    			}
    		}
    

    ********:有数字的输出千,百,十位

    if(x!=0){
    			sum=0;
    			jishuqi=1;
    			printf("%c", 'a'+x);
    			switch(y){
    				case 1: printf("Q"); break;
    				case 2: printf("B"); break;
    				case 3: printf("S"); break;
    			}
    		}
    	}
    

    ********:下面这个用来判断是否有万位上的数字

    if(y!=0){
    		printf("W");
    	}
    

    第四步:输出千以下位,大概同万位运算方法一样

    总结:这个万位的输出和千以下位的输出差不多,但是万位的细小条件更多,我原本还想自定义一个函数运算这两部分的,思考了,但是没深入思考,感觉应该是可行的。

    调试过程遇到的问题及解决方法

    这个题没调试过,直接输入,看输出结果,从结果判断问题所在。
    因为这个题是分开编译出来的,初始条件相同,并按要求输出,我是一个一个问题解决的:先解决第一个零不输出的问题,再解决中间零的输出问题,最后解决最后一位是零的不输出问题。
    在这个题中,计数器我感觉很重要,我设计的这个程序很多地方的输出要靠计数器,我感觉这个题还不够简便,但是现在看的话感觉思路还是挺清晰的。

    运行结果截图

    努力努力
  • 相关阅读:
    SVM神经网络的术语理解
    优化问题中的正则项作用
    转 强烈推荐遗传算法入门例子
    21分钟 MySQL 入门教程
    C++中abs、fabs、fabsf的使用方法
    国内有哪些质量高的JAVA社区?
    <Eclipse 学习笔记> Eclipse 开发常用快捷键
    <Servlet 学习笔记 > Servlet 生命周期和工作原理
    HDU
    POJ
  • 原文地址:https://www.cnblogs.com/xqldc/p/10262367.html
Copyright © 2020-2023  润新知