• 币值转换


    题目:币值转换

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

    输入格式:
    输入在一行中给出一个不超过9位的非负整数。

    输出格式:
    在一行中输出转换后的结果。注意“零”的用法必须符合中文习惯。

    输入样例1:
    81322734

    输出样例1:
    iYbQdBcScWhQdBeSf

    输入样例2:
    6900

    输出样例2:
    gQjB

    1.实验代码

    int main ()
    {
        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'};//存单位,为将下标与位数对应,前两个单元存0
         char RESULT[17];//存结果,最多存9个数字,8个单位
         int n,k=0,bitnum=0,cur,pre;    //定义输入数字,结果数组索引,位数,当前位,前一位
         
         scanf("%d", &n);
         
         if(n==0)
         {
             printf("a");
             return 0;
         }
         while(n!=0)
         {
             cur = n % 10;
             n /= 10;
             bitnum++;
             
         if(cur)
         {
             if(bitnum>1)//如果不为个位,存单位 
             RESULT[k++] = UNIT[bitnum];
             
             RESULT[k++] = NUM[cur];//无论如何,存数字 
         }
         else//如果当前位为0 
         {
             if(bitnum==5)
             RESULT[k++] = UNIT[bitnum];
             
             if(pre!=0&&bitnum!=4&&bitnum!=1)//若不为万位,千位,个位,且前一位不为0
             RESULT[k++]=NUM[cur];//存当前的数字0
         }
             
             pre=cur;//注意及时保存当前位 
          }
          for(int i=k-1;i>=0;i--)//倒序输出结果 
          printf("%c",RESULT[i]);
          
          return 0;
    }
    

    2.设计思路

    需要一个有效数字即a-f的符号组,一个有效数字单位组合即S,B,Q,W,Y,还需要一个结果数组存放单位和数字的组合。

    3.存在的问题及解决方法

    (1)问题:不知道该如何解决,尝试了很多次都编译错误。
    (2)解决方法:自己查阅书籍,自学了数组的相关知识,上网查阅资料。

    4.运行结果截图

  • 相关阅读:
    ES7 cat API的小结
    zabbix5.0 使用elasticsearch7.6按日期索引存储历史数据
    Archlinux爬坑指南
    ArchLinux安装常用软件QQ、TIM、微信等常用软件(三)
    ArcnLinux安装KDE桌面环境(二)
    ArchLinux安装步骤(一)
    DDD领域驱动及落地方案
    Text Classification with Keras
    Mattermost Server安装及配置AD/LADP
    使用队列问题
  • 原文地址:https://www.cnblogs.com/buxiu888/p/10412659.html
Copyright © 2020-2023  润新知