首页 > 技术文章 > 2018秋寒假作业5—PTA编程总结2

lpf666 2019-02-17 20:51 原文

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 (void)
{
    int n, v, v1, v2, s=0, j, v3, q=1000, k=0, N=0; 
    scanf("%d", &n);
    v=n/100000000;
    if(value!=0)
	{
        printf("%cY",'a'+v);                 
    }
        v1=n%100000000;
        v2=value1/10000;                            
    while(q!=0)
	{                                     
        if(v2==0)
		{
            break;
        }
        j=v2/q;
        v2=v2%q;
        q=q/10;
        k++;
        if(v==0&&j==0)
		{                
            if(N!=1)
			{
                continue;
            }
        }
        if(j==0)
		{
            s++;
            if(s<=1)
			 {
                if(y!=4)
				{
                    printf("%c", 'a');
                }   
            }
        }
        if(x!=0
		){
            s=0;
            N=1;
            printf("%c", 'a'+j);
            switch(k){
                case 1: printf("Q");
			    break;
                case 2: printf("B");
			    break;
                case 3: printf("S"); 
				break;
            }
        }
    }
    if(k!=0)
	{
        printf("W");                                  
    }
    s=0;                                      
    q=1000;
    y=0;
    N=0;
    v3=n%10000;                   
    while(q!=0){
        j=v3/q;
        v3=v3%q;
        q=q/10;
        k++;
        if((n%100000000)/10000==0&&x==0){
            if(N!=1){
                continue;
            }
        }
        if(v3!=0)
		{
            if(x==0)
			{
                sum++;
                if(sum<=1)
				 {
                    printf("%c", 'a');
                 }
            }
        }
        if(j!=0){
            s=0;
            N=1;
            printf("%c", 'a'+j);
            switch(k){
                case 1: printf("Q");
				break;
                case 2: printf("B"); 
				break;
                case 3: printf("S"); 
				break;
            }
        }
    }
        if(n==0)
		{
        printf("%c", 'a');
    }   
} 

  

 

  

  2) 设计思路

调试过程遇到的问题及解决方法

首先这道题在思路上就遇到了一些问题,我当时的想法是将每一部分都分开用while判断是否为0,但是后面做出来后遇到了许多麻烦(在多个0只显示一个的问题上犯愁),在咨询了数位大佬后选择了这种将万位一下一次性处理,我也试过所有的数一起编写,但是我最后还是失败了,一直显示错误,我估摸着还是因为在出现多个0时我的处理出现了问题。但是我觉得一起编写应该是最简单的一种方法了,而且应该是可行的。

 运行结果截图

 

 

推荐阅读