zoukankan      html  css  js  c++  java
  • 寒假作业二

    7-1 币值转换 (20 分)
    输入一个整数(位数不超过9位)代表一个人民币值(单位为元),请转换成财务要求的大写中文格式。如23108元,转换后变成“贰万叁仟壹百零捌”元。为了简化输出,用小写英文字母a-j顺序代表大写数字0-9,用S、B、Q、W、Y分别代表拾、百、仟、万、亿。于是23108元应被转换输出为“cWdQbBai”元。
    1.实验代码。

    include<stdio.h>
    int main ()
    {
    int n, initial_n;
    scanf("%d", &n);
    initial_n = n;

    char num[10] = {'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j'};
    char unit[8] = {'S', 'B', 'Q', 'W', 'S', 'B', 'Q', 'Y'};
    char result[17]={0};

    int i, last_i = n % 10;
    int j = 0;
    int count_n = 0;
    while (n > 0) {
    i = n % 10;
    n /= 10;
    count_n ++;
    if (i == 0 && (count_n % 4) > 1) {
    if (last_i != 0) {
    result[j++] = num[i];
    }
    }
    if (count_n == 5 && i == 0 && initial_n < 100000000) {
    result[j++] = unit[count_n];
    }
    if (count_n > 1 && i != 0) {
    result[j++] = unit[count_n];
    }
    if (i != 0) {
    result[j++] = num[i];
    }
    last_i = i;
    }

    if (initial_n == 0) {
    result[j++] = num[i];
    }

    for (j=j-1; j>=0; j--) {
    printf("%c", result[j]);
    }
    printf(" ");

    return 0;
    }
    2、设计思路。
    第一步:定义主函数,对主函数进行预处理。
    第二步:定义整形变量n,initial_n.
    第三步:调用scanf语句接收变量n,initial_n.
    第四步:赋值initial_n=n.
    第五步:定义一个数组num,它有10个字符变量,再依次赋值=a,b,c,d,e,f,g,h,i,j,再定义数组unit,有8个字符变量,再依次赋值=S,B,Q,W,S,B,Q,Y,分别代表个,十,百,千,万,十万,百万,千万,亿。再定义数组result,有17字符变量,全都赋值为0,这是为了输入范围不会超过亿,输出格式也就只有17位了。
    第六步:再定义赋值整型变量i,last_i=n%10,j=0,count_n=0.
    第七步:调用while语句,输入进入while循环条件n>0,利用
    i = n % 10;
    n /= 10;
    count_n ++;计算出未知整数的最高单位数。
    第八步: 如果符合条件 if (i == 0 && (count_n % 4) > 1) {
    if (last_i != 0) {
    result[j++] = num[i];
    } 输出result[1]=a。
    第九步:输入 if (count_n == 5 && i == 0 && initial_n < 100000000) {
    result[j++] = unit[count_n];
    }符合则输出result[2]=B.
    第十步:if (count_n > 1 && i != 0) {
    result[j++] = unit[count_n];输出result[3]=unit[count_n].
    第十一步:如果i!=0,输出 result[j++] = num[i]。
    第十二步:给last_i赋值等于i,并且一直循环该结构,直到跳出循环。
    第十三步:如果initial_n=0,输出 result[j++] = num[i];
    第十四步:用for语句使j递减,输出字符,result[j].
    第十五步:换行,输出结果,结束程序。
    3、本体调试过程中遇到的问题及解决办法。
    1、 i = n % 10;
    n /= 10;
    count_n ++;为什么先要用这个语句?
    解决办法:由于我们不知道什么时候该输出,因此我们要先输出最高位。

  • 相关阅读:
    神舟笔记本反厂后带来的惊喜与郁闷
    如今是否还要坚持asp.net,坚持程序员这个不怎么光荣的称号
    严援朝的一句名言
    一个专科生程序员的痛苦境遇
    overflow:hidden 文本不在over 范围,也不显示
    困扰很久的问题
    未来已来,4K激活字库产业新世代
    4K超高清,为字库产业,打开了数字家电的大门
    2012中文字库简单统计与分类
    图说字王数格纵系列
  • 原文地址:https://www.cnblogs.com/chenzg90826/p/10408501.html
Copyright © 2011-2022 走看看