寒假作业pta2

7-1 币值转换 (20 分)
输入一个整数(位数不超过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<math.h>
int n,s=0;
int main(void){
    int i,j,k,p=1,flag=1;
    int f(int q,int n);
    scanf("%d",&n);
    
    for(i=0;n/p>=10;i++){
        p=pow(10,i);
        s++;
    }
    if(n==0)
      printf("a");
    if(n<10&&n>=0)
     s=1;
    for(j=1;j<=s;j++){
        switch(f(j,n)){
            case 0:if(j!=s&&j!=s-4){
                if(f(j+1,n)==0)
                   flag=0;
                else
                   flag=1;
                if(flag)printf("a");break;
                };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;
        }
        if(f(j,n)==0&&j!=s&&j!=s-4) 
          continue;
        else{
            if(s==9&&j==5){
                if(f(2,n)==0&&f(3,n)==0&&f(4,n)==0&&f(5,n)==0)
                continue;
            }
        switch(s-j){
            case 1:printf("S");break;
            case 2:printf("B");break;
            case 3:printf("Q");break;
            case 4:printf("W");break;
            case 5:printf("S");break;
            case 6:printf("B");break;
            case 7:printf("Q");break;
            case 8:printf("Y");break;
        }
    }} 
    return 0;
}
int f(int q,int n)
{
    int k,a;
    if(q==1) 
       k=n/pow(10,s-1);
    else{
        a=n/pow(10,s-q+1);
        k=n/pow(10,s-q)-a*10;
    }
    return k;
}

思路:首先我们先将各数字和单位及其所对应的字符按题目意思相互对应,然后我们随机输入一个数,要判断它最高位是什么位,即从最高的单位(第九位,亿)做除法,若取得的结果为零,则不输出,且说明输入数最高位不是亿,然后再除以万(不是一千万,因为题目给出的有相对符号的单位里只有十百千万亿),相同的计算法则,以此除下去,若不为零,则先输出数字相对应的字符,然后输出单位上所对应的字符,最后把所得的余数继续除以下一个单位,所以我们需要用到循环结构对数值进行除法与求余。这样就可以输出对应的答案了。要注意的是几种特殊情况最小个位数和数字之间有零这两种。

问题:若数字中间有零该方法则不会准确输出正确答案
解决:在网络上查找资料并且询问朋友以后,半懂半不懂的,还是回学校当面听大佬的讲解吧!
1581961-20190220220105301-1168876903.png

转载于:https://www.cnblogs.com/94ha-xc/p/10409547.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值