zoukankan      html  css  js  c++  java
  • 币值转换编程总结

    7-1 币值转换 (20 分)

    输入一个整数(位数不超过9位)代表一个人民币值(单位为元),请转换成财务要求的大写中文格式。如23108元,转换后变成“贰万叁仟壹百零捌”元。为了简化输出,用小写英文字母a-j顺序代表大写数字0-9,用S、B、Q、W、Y分别代表拾、百、仟、万、亿。于是23108元应被转换输出为“cWdQbBai”元。

    1、实验代码

    #include<stdio.h>
    #include<math.h>
    int result (int n)
    {
        switch(n)
            {
                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;
        }
    }
    
    int product (int m)
    {
        switch(m)
            {
                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 main()
    {
        int n,a,b=1,c[10]={0,1,2,3,4,5,6,7,8,9},d,e;
        scanf("%d",&n);
        for (a=0; n/b>=10; a++) {
        	b=pow(10,a);
    	}
            e=a;
        for(a=a; a>0; a--)
        {
            c[a]=n/pow(10,a-1);
            d=pow(10,a-1);
            b=n%d;
            n=b;
        } 
        if(e==0)    printf("a");
        else if(e%100000000==0) {   
                        result (e/100000000);
                    printf("Y");
                }
        else
            for(e=e; e>0; e--)
            {
                if(c[e]!=0) 
                    if(c[e+1]==0)
                    {
                        printf("a");
                        result (c[e]);
                        product (e);
                    }           
                    else
                    {   
                        result (c[e]);
                        product (e);
                    }
                else if(e==5)   printf("W");
            }       
    }
    
    
    

    2、设计思路

    第一步:定义变量表示输入的数据,再定义一个数组,在后面对输入数据的位数进行对应;
    第二步:定义两个函数,主要作用是对位数及数字进行对应的转换,利用switch语句进行单个对应转换;
    第三步:首先,对输入数据进行位数判断,利用for语句,然后再将这个数利用数组表示;
    第四步:接下来就是对这个数的每一位进行判断是否为零,若非零,则分别利用自定义函数进行数字,位数进行对应输出;
    第五步:再利用递减原理将这个数从高位到低位输出完为止。

    3、本题调试过程碰到的问题及解决方法

    如图

    问题:

    在最开始的时候,数组定义为九个元素的数组,因为亿位就是第九位,但忽略了九个都是零的情况,也就是还有第十位,所以部分正确;

    解决方法:

    将数组改为十个元素的数组,即可。

    4、运行结果截图

  • 相关阅读:
    关于题目中的内存限制
    手动实现最小堆和最大堆(优先队列)
    线性筛素数(欧拉筛)+前缀和优化
    并查集
    快速排序

    字典按中文姓名排序
    oc程序代码
    学生字典计算年龄差 随机50个数
    nsset
  • 原文地址:https://www.cnblogs.com/songguanhao/p/10349864.html
Copyright © 2011-2022 走看看