• 币值转换


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

    include <stdio.h>

    include <string.h>

    void printNumber(char *s, int i, int len);
    void printPlace(char *s, int, int);

    int main()
    {
    char s[11];
    int i, strLen;

    gets(s);
    strLen = (int)strlen(s);
    
    if (strLen == 1 && s[0] == '0') {
        printf("a
    ");
        return 0;
    }
    
    for (i=0; i<strLen; i++) {
        if (s[i] == '0') {
            if (strLen-i == 5) {
                if (s[1]!='0' || s[2]!='0' || s[3]!='0' || s[4]!='0' || strLen < 9) {
                    printf("W");
                }
            }
            if (s[i+1] != '0' && s[i+1] != '' && (strLen-i != 5)) {
                printf("a");
            }
            continue;
        }else {
            printNumber(s, i, strLen);
            if (strLen-i == 5) {
                if (s[1]!='0' || s[2]!='0' || s[3]!='0' || s[4]!='0' || strLen < 9) {
                    printf("W");
                }
            }
        }
        
        if (strLen-i == 9) {
            printf("Y");
        }
    }
    
    return 0;
    

    }

    void printNumber(char *s, int i, int len)
    {
    int num = s[i] - '0';

    switch (num) {
        case 0:
            printf("a");
            if (s[i] != '0') {
                printPlace(s, len-i, len);
            }
            break;
        case 1: printf("b"); printPlace(s, len-i, len); break;
        case 2: printf("c"); printPlace(s, len-i, len); break;
        case 3: printf("d"); printPlace(s, len-i, len); break;
        case 4: printf("e"); printPlace(s, len-i, len); break;
        case 5: printf("f"); printPlace(s, len-i, len); break;
        case 6: printf("g"); printPlace(s, len-i, len); break;
        case 7: printf("h"); printPlace(s, len-i, len); break;
        case 8: printf("i"); printPlace(s, len-i, len); break;
        case 9: printf("j"); printPlace(s, len-i, len); break;
    }
    

    }

    void printPlace(char *s, int i, int len)
    {
    switch (i) {
    case 1: break;
    case 2: printf("S"); break;
    case 3: printf("B"); break;
    case 4: printf("Q"); break;
    case 5: break;
    case 6: printf("S"); break;
    case 7: printf("B"); break;
    case 8: printf("Q"); break;
    }
    }
    我的思路:从最大数位开始逐个取出各数字 ,然后逐个输出,在记录下来,然后与同学讨论,请教问题,当有0时要单独判断,若前一位不为零,则输出零,不为0的时候可以直接规律输出,当数位大于万位时是特殊情况,需要调整大写字母的输出反之则直接按规律输出。

  • 相关阅读:
    Git学习1:Git起步
    [转载]AMOLED结构详解,BOE专家给你分析驱动补偿
    [C#] Microsoft .Net框架SerialPort类的用法与示例
    API 的历史
    AMOLED原理介紹
    [C#] SHA1校验函数用法
    示波器基本原理之三:存储深度
    示波器基本原理之二:采样率
    示波器基本原理之一:带宽
    数字转中文
  • 原文地址:https://www.cnblogs.com/lyf593-/p/10407266.html
Copyright © 2020-2023  润新知