• 2019寒假作业2 编程总结


    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> 
    #include<string.h>         //字符串操作函数,如求字符串长度 
    int main() 
    { 
        int lenth,l; 
        char str[10];          //定义字符串数组 
        gets(str); 
        lenth=strlen(str);     //求长度 
        while(lenth>9)
    	{ 
            lenth--; 
        } 
        l=lenth;               //用l来保存当前位数,即千位,百位。 
        int t=1;               //定义t用于判断万位是否输出单位(W) 
        if(str[1]=='0'&&str[2]=='0'&&str[3]=='0'&&str[4]=='0')
    	{ 
            t=0;               //若万位,十万位,百万位,千万位都为零,则不需要输出单位万(W) 
        }
        else
    	{ 
            t=1; 
        } 
        for(int i=0;i<lenth;i++,l--)
    	{ 
            char c=str[i]; 
            switch(c)
    	    { 
                case'0':c='a';break; 
                case'1':c='b';break; 
                case'2':c='c';break; 
                case'3':c='d';break; 
                case'4':c='e';break; 
                case'5':c='f';break; 
                case'6':c='g';break; 
                case'7':c='h';break; 
                case'8':c='i';break; 
                case'9':c='j';break; 
                default:break; 
            } 
            if(lenth==1&&str[0]=='0')
    	    { 
                printf("a"); 
                return 0;       //当只输入一个数时,且该数为0,即数组长度只有1位,且str[0]=='0'。 
            } 
            if(c=='a') 
    	    {                   //0特殊,为0(a)的字符单独考虑 
                if(l==5&&t)
    		    { 
                    printf("W");//当0在万位时,直接输出单位万,不需要输出零(a) 
                }
    	        else
    	        {                               //当0不在万位时 
                    for(i++,l--;i<lenth;i++,l--)
    		    	{                           //看0的下几位是否为0 
                        if(str[i]=='0')
    	                {                       //数组中的字符仍是数字,所以要用数字’0‘判断 
                            if(l==5&&t)
    		    			{ 
    		                    printf("W");    //下几位若有万位为0的,直接输出单位万(w) 
                            } 
                        }                       //若为0的数中没有万位的,直接跳过,判断下一位,不需要输出任何东西 
                        else
    		            {                       //下面几位数中,0后面有不为0的数 
                            printf("a"); 
                            l++;i--;                   /*将l和i的值恢复到上一位为0的数所代表的值,因为break后,上面的for循环又要把l和i的 
                                               恢复到先前那个不为0的值所代表的值 */ 
                            break; 
                        } 
                    } 
                } 
            }
            else
    	    {                                   //字符不为0(a)。 
                printf("%c",c);                 //输出字符 
                switch(l)
    		    {                               //位数 
                    case 9:printf("Y");break; 
                    case 8:case 4:printf("Q");break; 
                    case 7:case 3:printf("B");break; 
                    case 6:case 2:printf("S");break; 
                    case 5:printf("W");break; 
                    default:break; 
                } 
            } 
        } 
        return 0; 
    }
    

    (2)设计思路

    第一步:运用字符串操作函数
    第二步:定义变量(整型与字符型)
    第三步:运用while语句判断出位数,再用switch语句选择每个数字对应的字符(详细讲解对应(1)中代码)
    第四步:打印结果

    (3)本题调试过程碰到问题及解决办法
    问题1:不会用字符串操作函数
    解决方法:找书上有关字符串操作函数的内容,然后仔细看,最后再查资料,看其他同学的博客

    问题2:零的情况考虑不全
    解决方法:自己慢慢思索,然后参看其他同学的博客

    问题3:不懂输出亿位, 万位,千位,百位,十位
    解决方法:查资料,看了几个大佬的博客

    问题4:不知道gets(str)的意思,并且不太懂数组的运用
    解决方法:搜视频看,看书,查资料

    (4)运行结果截图

  • 相关阅读:
    Treap仿set 模板
    线段树(区间更改,区间查最值)模板
    UVA 12345 Dynamic len(带修莫队)
    服务器配置环境以及部署项目流程
    使用SSH的scp命令行传输文件到远程服务器
    服务器部署javaweb项目
    在ubuntu服务器上安装mysql并配置外网访问
    在ubuntu服务器上配置tomcat
    在ubuntu服务器上配置jdk
    linux命令--解压与压缩
  • 原文地址:https://www.cnblogs.com/zmzhang/p/10295585.html
Copyright © 2020-2023  润新知