zoukankan      html  css  js  c++  java
  • 寒假作业2:币值转换

    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 ()
    {
        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!=0)
        {
            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;
    }
    

    搞了好久没搞出来,然后去参考了大佬的博客,然而还是没怎么搞懂

  • 相关阅读:
    定制自己的PHP语法-在PHP中实现unless
    欢迎使用CSDN-markdown编辑器
    在 Laravel 中通过 Artisan View 扩展包创建及删除应用视图文件
    直接可用的loading.js
    vue后退判断是否有历史记录,有就返回上一级,否则返回指定路由
    js防抖和节流
    IE增加Meta标签(IE=Edge,chrome=1)兼容IE问题
    如何覆盖 node_modules 里的文件
    js运行代码计时器
    vue打包font字体文件路径错误的问题处理
  • 原文地址:https://www.cnblogs.com/xirfly/p/10264245.html
Copyright © 2011-2022 走看看