币值转换

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

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

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

813227345

输出样例1:

iYbQdBcScWhQdBeSf

输入样例2:

6900

输出样例2:

gQjB

1.实验代码:

#include<stdio.h>
int main ()
{
    char NUM[10]={'a','b','c','d','e','f','g','h','i','j'};    //存数字 
    char UNIT[10]={0,0,'S','B','Q','W','S','B','Q','Y'};//存单位,为将下标与位数对应,前两个单元存0
     char RESULT[17];//存结果,最多存9个数字,8个单位
     int n,k=0,bitnum=0,cur,pre;    //定义输入数字,结果数组索引,位数,当前位,前一位
     
     scanf("%d", &n);
     
     if(n==0)
     {
         printf("a");
         return 0;
     }
     while(n!=0)
     {
         cur = n % 10;
         n /= 10;
         bitnum++;
         
     if(cur)
     {
         if(bitnum>1)//如果不为个位,存单位 
         RESULT[k++] = UNIT[bitnum];
         
         RESULT[k++] = NUM[cur];//无论如何,存数字 
     }
     else//如果当前位为0 
     {
         if(bitnum==5)
         RESULT[k++] = UNIT[bitnum];
         
         if(pre!=0&&bitnum!=4&&bitnum!=1)//若不为万位,千位,个位,且前一位不为0
         RESULT[k++]=NUM[cur];//存当前的数字0
     }
         
         pre=cur;//注意及时保存当前位 
      }
      for(int i=k-1;i>=0;i--)//倒序输出结果 
      printf("%c",RESULT[i]);
      
      return 0;
}

2.设计思路:
阅读题目——》开始——》用数组表示——》输入变量,定义字符——》判断n是否等于0——》比较a进行判断——》编写代码,进行程序循环——》输出结果——》结束
3.解决方法:
题目内容转换较为复杂,自己并不是很懂,然后是通过询问同学以及上网搜索完成的,还是准备想去了解一下更多的知识。
4.运行结果截图:
1583681-20190220215240394-533720344.png

转载于:https://www.cnblogs.com/mirenlin/p/10409506.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值