zoukankan      html  css  js  c++  java
  • 编程总结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)设计思路


    我尽力了,还有个自定义函数的流程图就没写上去了。

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

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


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

    4)运行截图

  • 相关阅读:
    C++分数类
    2019 SDN大作业
    个人作业-软工实践总结
    2019 SDN上机第7次作业
    2019 SDN上机第6次作业
    2019 SDN课程阅读作业(2)
    个人作业--软件评测
    2019 SDN上机第5次作业
    2019 SDN上机第4次作业
    2019 SDN第一次阅读作业
  • 原文地址:https://www.cnblogs.com/LeeMayZ/p/10396347.html
Copyright © 2011-2022 走看看