zoukankan      html  css  js  c++  java
  • 币值转换

    币值转换
    输入一个整数(位数不超过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()
    {
    int n,initial_n;
    scanf("%d",&n);
    initial_n=n; //保留初始值

    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'};    //舍弃前两位 
    char result[17]={0};      //9位数最多有17位输出
     
    int i,last_i=n%10;
    int j=0;
    int count_n=0;
    while(n>0)
    {   
        
        i=n%10;
        n/=10;
        count_n++;
        if(i==0&&(count_n%4)>1)         //从十位开始统计(个位 0 永远不输出 ) 
        {      
            if(last_i!=0)                           //如果前一位不等于 0 ,那就输出这个 0
            {       
                result[j++]=num[i];
            }
        }
        if(count_n==5&&i==0&&initial_n<100000000)
        {
            result[j++]=unit[count_n];      //万 W 是一定要输出的 
        } 
        if(count_n>1&&i!=0)
        {                                                 //非 0 不输出单位 
            result[j++]=unit[count_n];
        }
        if(i!=0)
        {                                                //处理非0数输出
            result[j++]=num[i];
        }
        last_i=i;                                     //保留 i 前一位的值用于处理0 
        }
    
    if(initial_n==0)
    {                                                    //处理特殊值 0 
        result[j++]=num[i];
    }
    
    for(j=j-1;j>=0;j--)
    {
        printf("%c",result[j]);
    }
    
    return 0;
    

    }
    设计思路:

    正确实验截图:

  • 相关阅读:
    贪心例题
    第十六周总结
    软件工程个人课程总结
    冲刺二十一天
    浅谈async/await
    浅谈设计模式的六大原则
    dotnetcore配置框架简介
    这一次,终于弄懂了协变和逆变
    科个普:进程、线程、并发、并行
    五分钟了解Semaphore
  • 原文地址:https://www.cnblogs.com/husiyu/p/10361213.html
Copyright © 2011-2022 走看看