zoukankan      html  css  js  c++  java
  • PTA编程总结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

    1).实验代码

    #include<stdio.h>
    int main()
    {
    char M[10]={'a','b','c','d','e','f','g','h','i','j'};//存数字
    char N[10]={0,0,'S','B','Q','W','S','B','Q','Y'};//存单位,为将下标与位数对应,前两个单元存0
    char J[17];//存结果,最多存9个数字,8个单位
    int n,k=0,m=0,cur,pre;//定义输入数字,结果数组索引,位数,当前位,前一位
    printf("输入一个9位以内的数:");
    scanf("%d",&n);
    if(!n)
    {
    printf("%d",M[0]);//注意若输入数为0,输出a
    return 0;
    }
    while(n)//否则从低位到高位取位判定
    {
    cur=n%10;
    n/=10;//注意n及时除10
    m++;
    if(cur)//如果当前位不为0
    {
    if(m>1) //如果不为个位,存单位
    J[k++]=N[m];
    J[k++]=M[cur];//无论如何,存数字
    }
    else//如果当前位为0
    {
    if(m==5)//若为万位
    J[k++]=N[m];//必存单位
    else if(pre!=0&&m!=4&&m!=1)//若不为万位,千位,个位,且前一位不为0
    J[k++]=M[cur];//存当前的数字0
    }
    pre=cur;//注意及时保存当前位
    }
    for(int i=k-1;i>=0;i--)//倒序输出结果
    printf("%c",J[i]);
    return 0;
    }

     2) 设计思路

    首先需判定输入数为0的情况,一般的处理手段是输出a,return 0。如果输入数不为0,那么将输入数从低到高取位判定。取得的当前位有0和非0之分,若当前位非0,且当前位数不为1即当前位不为个位,则存放单位与数字。注意由于一开始不知道输入数的位数,故结果数组的索引只能从低到高,一般从0开始,所以先存放单位,后存放数字。若当前位为0,则大概需要注意下述3种情况:
    1.有单位,无数字:万位
    2.无单位,无数字:
    2.1 千位,个位
    2.2 除万位之外,前面一位为0
    3.无单位,有数字:除万位,千位,个位之外,前面一位不为0
    上述情况的操作流程大致为:
    1.若当前位为万位,则必存单位
    2.若当前位不为万位,则又需要分情况讨论:2.1 当前位为千位或个位,不存数字
    2.2 当前位不为千位,且不为个位,但前面一位为0,也不存数字
    2.3 当前位不为千位,且不为个位,前面一位非0,存数字

    3)本题调试过程碰到问题及解决办法

    问题:最后输出一开始格式用错了,导致输出全部为数字

    解决方法:开始用的%d ,后来改成了%c

    4).运行结果截图

  • 相关阅读:
    BZOJ 1707 [Usaco2007 Nov]tanning分配防晒霜
    BZOJ2697:特技飞行
    Bridging signals(NlogN最长上升子序列)
    HDU 4291 A Short problem(矩阵+循环节)
    计蒜之道 初赛第一场B 阿里天池的新任务(简单)
    1008: [HNOI2008]越狱
    1022: [SHOI2008]小约翰的游戏John
    1192: [HNOI2006]鬼谷子的钱袋
    2456: mode
    BZOJ-1968
  • 原文地址:https://www.cnblogs.com/qzy7/p/10414784.html
Copyright © 2011-2022 走看看