zoukankan      html  css  js  c++  java
  • 寒假二:币值转换

     
     
    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>
    #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");
            }       
    }
    

      设计思路

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

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

    如图

    问题:

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

    解决方法:

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

         运行结果截图

     
  • 相关阅读:
    go语言中文网
    理解Golang包导入
    如何保证对象的唯一性
    模拟java.util.Collection一些简单的用法
    静态代码块,构造代码块,局部代码块演示
    java中paint方法和paintComponent方法的不同
    java中异常注意问题(发生在多态是的异常问题)
    java中异常注意的细节2
    java中异常注意的细节1
    java中匿名类的注意细节
  • 原文地址:https://www.cnblogs.com/li-xue/p/10409834.html
Copyright © 2011-2022 走看看