【PTA】念数字题

输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出fu字。十个数字对应的拼音如下:

0: ling  1: yi  2: er  3: san  4: si  5: wu  6: liu  7: qi  8: ba  9: jiu

输入格式:
输入在一行中给出一个整数,如:1234。

提示:整数包括负数、零和正数。

输出格式:
在一行中输出这个整数对应的拼音,每个数字的拼音之间用空格分开,行末没有最后的空格。如 yi er san si。

输入样例:


-600

输出样例: 


fu liu ling ling

整体思路就是:输入数字,通过数字对应二维数组里的拼音,将其正序输出。

正序输出的思路是:先得到一个数m,这个数m是输入数n的总位数(假设输入数n是54321,则这个数m是10000),用n除以这个数m,得到的就是输入数n的最大位。同时每循环一次,n去掉最高位,m除以10,这样就能正序输出每一位了。

#include <stdio.h>
int main()
{
    char a[10][5]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};  //定义一个二维数组,每行分别存储各个数字的拼音
    int n,t;                                                                 //同时还满足了数字几对应的就是几的拼音,如a[0]对应的就是'ling'
    scanf("%d",&n);       //输入数字
    if(n<0){
        printf("fu ");
        n=-n;             //如果是负数先化为正数,并输出“fu”加空格
    }
    t=n;
    int mask=1,d;
    while(t>9){
        t/=10;
        mask*=10;         //通过循环得到输入数的总位数
    }
    while(mask>0){
        d=n/mask;         //得到最高位数字
        printf("%s",a[d]);//用数字对应每个拼音的位置,并输出
        if(mask>9){       //如果mask<9,说明已经到了最后一位,不用再敲空格了
            printf(" ");
        }
        n=n%mask;         //每循环一次,输入数n消掉最左边那位数,同时mask也主动往下降一位
        mask/=10;
    }
    return 0;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

君莫笑swift

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值