zoukankan      html  css  js  c++  java
  • 2018秋寒假作业5—PTA编程总结2

    1.实验代码:

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

    include<stdio.h>

    include<math.h>

    int main()
    {
    int yuan,chu_2,chu_1,i,p,a=0;
    char op;
    scanf("%d",&yuan);

    chu_1=yuan;
    for(i=-1;chu_1!=0;i++){    
        chu_1=chu_1/10;
    }
    int A[i];
    chu_1=yuan;
    for(a=0;chu_1!=0;i--,a++){    //从最大数位开始逐个取出各数字 
        p=pow(10,i);
        chu_2=chu_1/p;
        chu_1=chu_1%p;   
        switch(chu_2){     //从最大数位开始逐个输出  
             case 0:op='a';break;
             case 1:op='b';break;
             case 2:op='c';break;
             case 3:op='d';break;
             case 4:op='e';break;
             case 5:op='f';break;
             case 6:op='g';break;
             case 7:op='h';break;
             case 8:op='i';break;
             case 9:op='j';break;
        }
        A[a]=chu_2; //记录数字 
        if(chu_2==0){ //零为特殊情况,需要单独判断 
             if(i==6&&A[a-1]!=0)
                 printf("W");
             if(i==5&&A[a-1]!=0)
                 printf("W");
             if(i==4&&A[a-1]!=0)
                 printf("W");
             if(A[a-1]!=0&&i<8)     //若前一位不为零,则输出零 
                 printf("%c",op);
        }
        if(chu_2!=0)     //不为零的情况可以直接按规律输出
             printf("%c",op); 
        if(i==5&&chu_2!=0)     //当数位大于万位时是特殊情况,需要调整大写字母的输出
             printf("S");
        if(i==6&&chu_2!=0)
             printf("B");
        if(i==7&&chu_2!=0)
             printf("Q");         
        if(i==8&&chu_2!=0)
             printf("Y");
        if(i-1>=0&&chu_2!=0&&i-1<=4)     //数位小于或等于万位时为通常情况,直接按规律输出    
             switch(i){
                 case 1:printf("S");break;
                 case 2:printf("B");break;
                 case 3:printf("Q");break;
                 case 4:printf("W");break; 
        }
        }
        if(yuan==0)    //若币值为零,则直接输出字母a后结束程序
             printf("a");
    return 0;
    

    }

    2.设计思路

    输入对应的数值
    int a,b,c,d,e,n,i,j,m,N,k;
    调用scanf函数和for语句
    代码分为输出代表数字的小写字母部分和代表数位的大写字母部分。
    切记从高位数到低位数的分离
    小写字母部分又分为数字为零的特殊情况和非零的通常情况,大写字母部分又分为数位大于万位的特殊情况和小于等于万位的通常情况。
    第三步通常情况都为直接输出对应的字母,特殊情况按情况讨论。

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


    解决方法
    在编译器上面进行编译运行,发现错误,并翻阅书籍,然后一个一个解决错误

    4.运行结果截图
    ![](https://img2018.cnblogs.com/blog/1582777/201902/1582777-20190219152708426-1911425784.png

  • 相关阅读:
    c# 之 事务
    Asp.Net 之 js/jquery获取服务器端控件
    产品能力框架图
    软件测试职业发展规划图
    Loadrunner 工作原理图
    Linux内核性能测试工具全景图
    Linux 性能监控分析
    软件藏宝图
    Haproxy 8种算法+Session共享
    Keepalived+Haproxy实现高可用负载均衡
  • 原文地址:https://www.cnblogs.com/freezinng/p/10401359.html
Copyright © 2011-2022 走看看