• 币值转换


    1.代码:

    #include<stdio.h> 
    int main (void)
    {
        int n, value, value1, value2, sum=0, x, value3, qian=1000, y=0, jishuqi=0;
        scanf("%d", &n);
        value=n/100000000;
        if(value!=0){
            printf("%cY", 'a'+value);                      /*输出亿位*/
        }
            value1=n%100000000;
        value2=value1/10000;                                 /*得到万位数字*/
        while(qian!=0){                                            /*输出万位*/
            if(value2==0){
                break;
            }
            x=value2/qian;
            value2=value2%qian;
            qian=qian/10;
            y++;
            if(value==0&&x==0){               
                if(jishuqi!=1){
                    continue;
                }
            }
            if(x==0){
                sum++;
                if(sum<=1) {
                    if(y!=4){
                        printf("%c", 'a');
                    }  
                }
            }
            if(x!=0){
                sum=0;
                jishuqi=1;
                printf("%c", 'a'+x);
                switch(y){
                    case 1: printf("Q"); break;
                    case 2: printf("B"); break;
                    case 3: printf("S"); break;
                }
            }
        }
        if(y!=0){
            printf("W");                                      /*输出万位结束*/
        }
        sum=0;                                                    /*输出千位以下需要重新赋初始值,因为在万位运算的时候值变化了*/
        qian=1000;
        y=0;
        jishuqi=0;
        value3=n%10000;                                    /*得到千以及以下数字*/
        while(qian!=0){
            x=value3/qian;
            value3=value3%qian;
            qian=qian/10;
            y++;
            if((n%100000000)/10000==0&&x==0){
                if(jishuqi!=1){
                    continue;
                }
            }
            if(value3!=0){
                if(x==0){
                    sum++;
                    if(sum<=1) {
                        printf("%c", 'a');
                    }
                }
            }
            if(x!=0){
                sum=0;
                jishuqi=1;
                printf("%c", 'a'+x);
                switch(y){
                    case 1: printf("Q"); break;
                    case 2: printf("B"); break;
                    case 3: printf("S"); break;
                }
            }
        }
            if(n==0){
            printf("%c", 'a');
        }  
    }

    2.

    设计思路

    第一步:整体来看,把他们区分为三个区间,分别是亿,万,千以下
    第二步:输出亿位,这个很简单
    第三部:输出万位,这个考虑的就有很多,比如首位是零,还有连续的零,最后一个是零,下面一一讲解
    ********:第一:比如亿位为零且万位第一位位为零,那么这个零不能输出

    ********:第二:万位中间有两个零,但按我们中文规则只能输出一个零,且没有“零百”,“零十”,而且最后一位为零不输出

    ********:有数字的输出千,百,十位

    ********:下面这个用来判断是否有万位上的数字

    第四步:输出千以下位,大概同万位运算方法一样

    思维结构图:

  • 相关阅读:
    转贴:CSS伪类与CSS伪元素的区别及由来具体说明
    Docker + Consul 多数据中心模拟
    Spring之事件发布系统
    ExecutorService的submit方法的坑
    固定频率调用接口方案
    叠罗汉III之推箱子
    叠罗汉II
    叠罗汉I
    滑雪
    华为OJ:火车进站
  • 原文地址:https://www.cnblogs.com/wonzenkei/p/10362672.html
Copyright © 2020-2023  润新知