编程总结2

题目:

输入一个整数(位数不超过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>
#include<math.h>
int n,s=0;
int main()
{
    int i,j,m,p=1,flag=1;  //flag是判断结果出口的标记;
    int f(int x,int n);   //自定义函数用于从高位起逐个得到单个数,再用switch语句判断其相应字母;
    scanf("%d",&n);
    
    for(i=0;n/p>=10;i++){     
        p=pow(10,i);
        s++;   //s计算的是输入的n的位数;
    }
    if(n==0) printf("a");    //输入的n=0的情况;
    if(n<10&&n>=0) s=1;   //n是个位数的情况;
    for(j=1;j<=s;j++){   //j用于表示n的各个数字的位置;
        switch(f(j,n)){
            case 0:if(j!=s&&j!=s-4){
                if(f(j+1,n)==0) flag=0; //当前位是0但当前位不是万位也不是个位,若与其相邻的低位也是0时,flag=0,
                                        //若与其相邻的低位不是0时,flag=1,输出a
                else flag=1;
                if(flag)printf("a");break;
                };break;
            case 1:printf("b");break;
            case 2:printf("c");break;
            case 3:printf("d");break;
            case 4:printf("e");break;
            case 5:printf("f");break;
            case 6:printf("g");break;
            case 7:printf("h");break;
            case 8:printf("i");break;
            case 9:printf("j");break;
        }
        if(f(j,n)==0&&j!=s&&j!=s-4) continue;  //(当前位是0但当前位不是万位也不是个位)
        else{
            if(s==9&&j==5){
                if(f(2,n)==0&&f(3,n)==0&&f(4,n)==0&&f(5,n)==0)//千万位、百万位、十万位、万位都是0时,不输出单位;
                continue;
            }
        switch(s-j){
            case 1:printf("S");break;
            case 2:printf("B");break;
            case 3:printf("Q");break;
            case 4:printf("W");break;
            case 5:printf("S");break;
            case 6:printf("B");break;
            case 7:printf("Q");break;
            case 8:printf("Y");break;
        }
     }
    } 
    return 0;
}
int f(int x,int n)
{
    int m,a;
    
        a=n/pow(10,s-x+1);
        m=n/pow(10,s-x)-a*10;
    
    return m;
}  
2)设计思路

1581791-20190218194911332-328215108.png
我尽力了,还有个自定义函数的流程图就没写上去了。

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

1.连续多个0不知如何表示;

1581791-20190218202539571-629378820.png
解决方案:用if语句判断连续多个0但不是万位和个位时只读一个零,如果n是个九位数,则当千万位、百万位、十万位、万位都是0时,不输出相应的单位。

4)运行截图

1581791-20190218203356024-1036389525.png

转载于:https://www.cnblogs.com/LeeMayZ/p/10396347.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值