题目二

题目二

币值转换

输入一个整数(位数不超过9位)代表一个人民币值(单位为元),请转换成财务要求的大写中文格式。如23108元,转换后变成“贰万叁仟壹百零捌”元。为了简化输出,用小写英文字母a-j顺序代表大写数字0-9,用S、B、Q、W、Y分别代表拾、百、仟、万、亿。于是23108元应被转换输出为“cWdQbBai”元。
输入格式:
输入在一行中给出一个不超过9位的非负整数。
输出格式:
在一行中输出转换后的结果。注意“零”的用法必须符合中文习惯。
输入样例1:
813227345
输出样例1:
iYbQdBcScWhQdBeSf
输入样例2:
6900
输出样例2:
gQjB

正确实验代码:

#include<stdio.h>
#include<string.h>
int main()
{
  char a[10]={'a','b','c','d','e','f','g','    h','i','j'};
  char b[]={' ','         ','S','B','Q','W','S','B','Q','Y'};
  char num[10];
  gets(num);
  int l=strlen(num);
  int n;
  int i=0;
  int ling=0;
  int k=0;                   
  if(num[0]=='0'&&l==1) printf("a");      //0的情况,但测试点不包含这个
  else
  while(l-->0)
  {
    n=num[i++]-'0';
    if(n!=0)
    {
      if(ling==1)  
          printf("a");
      printf("%c",a[n]);
      ling=0;
    }
    else
    {
        ling=1;
        if(l==4&&k==1) printf("W");
        continue;
    }                                        //按照中文习惯,四位数一段规律,再考虑万怎么处理
    if(l>0)
    {
        if(l>4&&l<8) k=1;
        printf("%c",b[l+1]);
    }
  }
  return 0;
}

正确实验截图:

1580824-20190216233153906-2036884925.png

设计思路:

1580824-20190220224109206-1974064359.png

错误实验代码:

#include<stdio.h>
int main()
{
    int n;
    scanf("%d",&n);
    int i=100000000,j,k=8;
    if(n==0){
        printf("a",n);
    }
    while(n>0){
        j=n/i;
        if(j!=0){
            break;
        }
        i=i/10;
        k--;
    }
    char     sum[9]={0,'S','B','Q','W','S','B','Q','Y'};
    for(;n>0;k--){
        j=n/i;
        switch(j){
        case 0:printf("a",j);break;
        case 1:printf("b",j);break;
        case 2:printf("c",j);break;
        case 3:printf("d",j);break;
        case 4:printf("e",j);break;
        case 5:printf("f",j);break;
        case 6:printf("g",j);break;
        case 7:printf("h",j);break;
       case 8:printf("i",j);break;
        case 9:printf("j",j);break;
        }
        if(j!=0){
            printf("%c",sum[k]);
        }
        n=n-j*i;
        i=i/10;
    }
    return 0;
}

总结:

这个题之前我不是这样编写的,但是后来发现中间有一些错误的方法,然后去网上看到一个用数组的方法做方便很多,然后就借鉴了这个做法

转载于:https://www.cnblogs.com/LJL555/p/10389837.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值