PAT 1002 写出这个数

//QUESTION
/*
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。

输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10^100。

输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。

输入样例:
1234567890987654321123456789
输出样例:
yi san wu
*/

#include <stdio.h>
int ctoi(char num){//把一个char型数字,转化成int
    return num - '0';
}
int main(){
    int store[3];//store各位保存一个count的位数,因为count之和最大不过900,所以三位就够用
    char num[100];//为了能够存下10^100,这么大个数。而C语言中整型数据类型没有能存得下的
    scanf("%s",&num);  
    int i = 0;
    int count = 0;
    while(num[i] != '\0'){
        count += ctoi(num[i]); 
        i ++;
    }
    for(i = 0;count;i ++){
        store[i] = count % 10;
        count /= 10;
    }
    i--;
    for(;i >= 0;i --){
        switch(store[i]){
            case 0:
                printf("ling");break;
            case 1:
                printf("yi");break;
            case 2:
                printf("er");break;
            case 3:
                printf("san");break;
            case 4:
                printf("si");break;
            case 5:
                printf("wu");break;
            case 6:
                printf("liu");break;
            case 7:
                printf("qi");break;
            case 8:
                printf("ba");break;
            case 9:
                printf("jiu");break;
        }
        if (store[i] != '\0')//此处尤为精妙,也是我没有意料到的
                            // 
                        printf(" ");
                else
                        printf("\n");
    }
} 
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值