zoukankan      html  css  js  c++  java
  • 币值转换

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

    输入格式:
    输入在一行中给出一个不超过9位的非负整数。

    输出格式:
    在一行中输出转换后的结果。注意“零”的用法必须符合中文习惯。

    include <stdio.h>

    include <math.h>

    int main()
    {
    int a,b,c,d,e,n,i,j,m,N,k;
    scanf("%d",&N);
    a=b=N;
    if(a==0){
    printf("a");
    }
    for(i=0;a>0;i++){
    a=a/10;
    }
    c=i;
    for(i;i>0;i--){
    n=1;
    e=0;
    for(m=i-1;m>0;m--){
    n=n*10;
    }
    a=b/n;

               b=b-a*n;
    
               switch(a){
               case 0: printf("a"); 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;
               }
               switch (i) {
               case 2: printf("S"); break;
               case 3: printf("B"); break;
               case 4: printf("Q"); break;
               case 5: printf("W"); break;
               case 6: printf("S"); break;
               case 7: printf("B"); break;
               case 8: printf("Q"); break;
               case 9: printf("Y"); break;
               }
               j=0;
               for(d=b;d>0;j++){
               d=d/10;
               }
               j=i-j-1;
               if(c<9&&i>5&&j>2){
                    printf("W");
               }
               j=0;
               for(d=b;d>0;j++){
                    d=d/10;
               }
               if(j!=0){
               e=i-j-1;
               }else{
                    i=0;
               }
               if(e>3&&i>4||e==2&&i<4){
                    printf("a");
                    i=j+1;
               }else if(e==2&&i>1){
                    printf("a");
                    i=i-2;	
               }else if(j<4&&c<9&&j!=0&&e!=1&&e!=0){
                    printf("a");
                    i=j+1;
               }else if(e==1){
                    printf("a");
                    i=j+1;
               }else{
    
                    i=j+1;
                    }
               }
               return 0;
          }
    

    (2)设计思路
    1.首先定义变量。
    2.判断特殊情况。
    3.运用switch输入。
    4.输出答案。
    (3)错误及解决方法


    错误:最小值判断错误
    解决方法:查找资料改编程。
    (4)运行结果如图

  • 相关阅读:
    syslog+rsyslog+logstash+elasticsearch+kibana搭建日志收集
    行为型模式(一)
    spring cloud Sleuth
    Java面试题(基础)
    Java笔试题
    Idea创建SpringBoot项目整合Hibernate
    Java中遍历Map的四种方式
    SQL面试题
    Linux入门
    Spring Boot AOP Demo
  • 原文地址:https://www.cnblogs.com/1211li/p/10406898.html
Copyright © 2011-2022 走看看