题目二 币值转换

币值转换

 

输入一个整数(位数不超过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;
}

正确实验截图:

错误实验代码:

#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; }

这个题之前我是想用switch编写的,但是编写过后发现中间的0没办法控制输出,然后在网上看到一个大佬用数组的方法做方便很多,然后就借鉴了这个大佬的做法,希望有哪个大佬能帮我修改修我的代码

输入一个整数(位数不超过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;
}

正确实验截图:

错误实验代码:

#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; }

这个题之前我是想用switch编写的,但是编写过后发现中间的0没办法控制输出,然后在网上看到一个大佬用数组的方法做方便很多,然后就借鉴了这个大佬的做法,希望有哪个大佬能帮我修改修我的代码

猜你喜欢

转载自www.cnblogs.com/LJL555/p/10371913.html