• 寒假作业2 7-1 币值转换


    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
    

    1)代码

    #include<stdio.h>
    #include<math.h>
    int aa(int a);
    int bb(int b);
    int main()
    {
    	int a/*输入数据*/,b/*总位数*/,c=1/*媒介*/,d[10]={1,1,1,1,1,1,1,1,1,1}/*各个位上的数字*/,e/*媒介*/,f/*总位数*/;
    	scanf("%d",&a);
    		/*总位数*/
    	for(b=0;a/c>=10;b++)
    		{
    	        c=pow(10,b);
    	    } 
    	    f=b;
    	    /*各个位上的数字*/
    	for(b;b>0;b--)
    	{
    		d[b]=a/pow(10,b-1);
    		e=pow(10,b-1);
    		c=a%e;
    		a=c;
    	}
    	/*输出*/ 
    	if(f==0)	printf("a");
    	else if(f%100000000==0)	{	
    					bb(f/100000000);
    				printf("Y");
    			}
    	else
    		for(f;f>0;f--)
    		{
    			if(d[f]!=0)	
    				if(d[f+1]==0)
    				{
    					printf("a");
    					bb(d[f]);
    					aa(f);
    				}			
    				else
    				{	
    					bb(d[f]);
    					aa(f);
    				}
    			else if(f==5)	printf("W");
    		}		
    }
    
    int aa(int a)
    {
    	switch(a)
    		{
    			case 1: printf("");break;
    			case 2: printf("S");break;
    			case 3: printf("B");break;
    			case 4: printf("Q");break;
    			case 5: printf("W");break;
    			case 6: printf("S");break;
    			case 7: printf("B");break;
    			case 8: printf("Q");break;
    			case 9: printf("Y");break;
    	 }
    }
    
    int bb(int b)
    {
    	switch(b)
    					{
    				        case 1:printf("b");break;
    				        case 2:printf("c");break;
    				        case 3:printf("d");break;
    				        case 4:printf("e");break;
    				        case 5:printf("f");break;
    				        case 6:printf("g");break;
    				        case 7:printf("h");break;
    				        case 8:printf("i");break;
    				        case 9:printf("j");break;
    				    }
    }
    

    2)设计思路

    1、直接将数据每一位单独提出,判断此数所在数位

    		e=pow(10,b-1);
    		c=a%e;
    		a=c;
    

    2、读出并判断是否需要读出零(非零数前有零读一个零,若d[f]!=0且d[f+1]==0则printf("a") 再输出数据
    3、当存在万位及以上且要输出万位时只要输出一个万 if(f==5) printf("W");

    注意

    本题可以使用计算的方法进行运算但需要找到适当的函数,
    而找到适当函数难度较大却可以判断超过亿位的数据(只需要较小幅度更改)
    采用类似我的方法进行编程并不需要复杂的函数,简单粗暴的拆分判断但需要更改数据时更改很麻烦
    

    3)本题调试过程碰到问题及解决办法

    问题:未找到合适的函数
    解决:数学思维很重要

    4)运行结果截图

  • 相关阅读:
    NoSql
    事务简介
    c#批量插入
    SqlServer中获取所有数据库,所有表,所有字段
    企业需要k2来解放孤岛危机
    路在何方?移动互联网浪潮下房地产转型之路探讨
    卡斯柯经验谈│流程驱动项目管理的应用
    【干货来了】2014年K2房地产IT分享峰会
    【快报】基于K2 BPM的新一代协同办公门户实践交流会
    元祖签约K2 BPM,引领绿色健康食品!
  • 原文地址:https://www.cnblogs.com/5236288kai/p/10274315.html
Copyright © 2020-2023  润新知