PAT乙级1044 火星数字(C语言)

1044 火星数字 (20 分)
火星人是以 13 进制计数的:
地球人的 0 被火星人称为 tret。
地球人数字 1 到 12 的火星文分别为:jan, feb, mar, apr, may, jun, jly, aug, sep, oct, nov, dec。
火星人将进位以后的 12 个高位数字分别称为:tam, hel, maa, huh, tou, kes, hei, elo, syy, lok, mer, jou。
例如地球人的数字 29 翻译成火星文就是 hel mar;而火星文 elo nov 对应地球数字 115。为了方便交流,请你编写程序实现地球和火星数字之间的互译。
输入格式:
输入第一行给出一个正整数 N(<100),随后 N 行,每行给出一个 [0, 169) 区间内的数字 —— 或者是地球文,或者是火星文。
输出格式:
对应输入的每一行,在一行中输出翻译后的另一种语言的数字。
输入样例:
4
29
5
elo nov
tam
输出样例:
hel mar
may
115
13

分析

输入时,先输入一个字符串,然后读取字符,如果为换行符,则结束,否则再输入一个,然后判断是数字字符还是英文字符,如果为数字字符,求数字的大小,在求相应的字符,如果为英文字符,则分两种情况,是一个字符串还是两个字符串

代码

#include<stdio.h>
#include<string.h>
#include<ctype.h>
int main()
{
    
    
    int n;
    scanf("%d",&n);
    char ch,a[10],b[10];
    char c[13][10]={
    
    "tret","jan","feb","mar","apr","may","jun","jly","aug","sep","oct","nov","dec"};
    char d[12][10]={
    
    "tam","hel","maa","huh","tou","kes","hei","elo","syy","lok","mer","jou"}; 
    while(n--)
    {
    
    
        int  flag=0;
        scanf("%s",a);//读取第一个
        ch=getchar();//读取字符,如果为换行符则只有一个,如果不是则有两个
        if(ch!='\n')//判断是否有第二个字符串
        {
    
    
            scanf("%s",b);
            flag=1;//表示有两个的标志
        }
        int i=0,sum=0;
        if(isdigit(a[i]))//判断是否为数字字符
        {
    
    
            for(i=0;a[i]!='\0';i++)
            {
    
    
                sum=sum*10+a[i]-'0';//求数字大小
            }
            if(sum>=0&&sum<=12)//小于12
                printf("%s\n",c[sum]);
            else//含进位的
            {
    
    
                printf("%s",d[sum/13-1]);
                if(sum%13!=0)//表明不能被13整除
                    printf(" %s",c[sum%13]);
                printf("\n");
            }
            
        }
        else//英文字母
        {
    
    
            if(flag)//表明有两个字符串
            {
    
    
                for(i=0;i<12;i++)//找进位的
                {
    
    
                    if(strcmp(a,d[i])==0)
                    {
    
    
                        sum=sum+13*(i+1);
                        break;
                    }
                }
                for(i=0;i<13;i++)//找0-12的
                {
    
    
                    if(strcmp(b,c[i])==0)
                    {
    
    
                        sum+=i;
                        printf("%d\n",sum);
                        break;
                    }
                }
            }
            else//仅一个字符串
            {
    
    
                int temp=1;//判断是否在进位中找到
                for(i=0;i<12;i++)
                {
    
    
                    if(strcmp(a,d[i])==0)//表明在进位中找到,为13的倍数
                    {
    
    
                        sum=sum+13*(i+1);
                        printf("%d\n",sum);
                        temp=0;
                        break;
                    }
                }
                for(i=0;temp&&i<13;i++)
                {
    
    
                    if(strcmp(a,c[i])==0)
                    {
    
    
                        sum+=i;
                        printf("%d\n",sum);
                        break;
                    }
                }
                
            }
        }
        
    }
}

猜你喜欢

转载自blog.csdn.net/qq_51517771/article/details/114109652