编程总结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
#include
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)设计思路

编程总结2_第1张图片
我尽力了,还有个自定义函数的流程图就没写上去了。

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

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

编程总结2_第2张图片
解决方案:用if语句判断连续多个0但不是万位和个位时只读一个零,如果n是个九位数,则当千万位、百万位、十万位、万位都是0时,不输出相应的单位。

4)运行截图

编程总结2_第3张图片

你可能感兴趣的:(编程总结2)