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 ++;为什么先要用这个语句?
    解决办法:由于我们不知道什么时候该输出,因此我们要先输出最高位。

  • 相关阅读:
    1093 Count PAT's(25 分)
    1089 Insert or Merge(25 分)
    1088 Rational Arithmetic(20 分)
    1081 Rational Sum(20 分)
    1069 The Black Hole of Numbers(20 分)
    1059 Prime Factors(25 分)
    1050 String Subtraction (20)
    根据生日计算员工年龄
    动态获取当前日期和时间
    对计数结果进行4舍5入
  • 原文地址:https://www.cnblogs.com/chenzg90826/p/10408501.html
Copyright © 2011-2022 走看看