• PAT乙级1044------火星数字 (20分)


    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(<),随后 N 行,每行给出一个 [0, 169) 区间内的数字 —— 或者是地球文,或者是火星文。

    输出格式:

    对应输入的每一行,在一行中输出翻译后的另一种语言的数字。

    输入样例:

    4
    29
    5
    elo nov
    tam
    
     

    输出样例:

    hel mar
    may
    115
    13

    思路:
    1.首先判断是火星文转化为数字还是数字转化为火星文
    2.数字转火星文直接查数组
    3.火星文转数字通过strcmp与数组中的火星文比较,然后转化为数字

    首次通过代码:
     1 #include<stdio.h>
     2 #include<string.h>
     3 
     4 int main(){
     5     int sum;
     6     char low[][5]={"tret","jan", "feb", "mar", "apr", "may", "jun", "jly", "aug", "sep", "oct", "nov", "dec"};
     7     char high[][4]={"!!!","tam","hel", "maa", "huh", "tou", "kes", "hei", "elo", "syy", "lok", "mer", "jou"};
     8     char a[10];
     9     char b[5];
    10     char c[5];
    11     scanf("%d",&sum);
    12     getchar();
    13     for(int i=0;i<sum;i++){
    14         gets(a);
    15         if(a[strlen(a)-1]>='0'&&a[strlen(a)-1]<='9'){
    16              int num=0;int weight=1;
    17              for(int j=strlen(a)-1;j>=0;j--){
    18                 num+=(a[j]-'0')*weight;
    19                 weight*=10;
    20             }
    21             int x=num/13;int y=num%13;
    22             if(num==0) printf("tret");
    23             else if(num>0&&y==0) printf("%s",high[x]);
    24             else {
    25                 if(x!=0) printf("%s ",high[x]);
    26                 printf("%s",low[y]);
    27             }
    28             if(i!=sum-1) printf("
    ");
    29         }
    30         else{
    31             int flag=1;int num=0;int flag1=0;
    32             for(int j=0;j<strlen(a);j++){
    33              if(a[j]==' ') {
    34                  flag=0;
    35              }
    36              
    37              else if(flag){
    38               b[j]=a[j];
    39               b[j+1]='';
    40            }
    41            else {
    42             c[j-4]=a[j];
    43             c[j-3]='';
    44             flag1=1;
    45            }
    46          }
    47              for(int j=0;j<13;j++){
    48                if(strcmp(b,low[j])==0){
    49                    num+=j;
    50                    break;
    51                }
    52               if(strcmp(b,high[j])==0){
    53                    num+=j*13;
    54                    break;
    55                }
    56              }
    57                 if(flag1){
    58                   for(int j=0;j<13;j++)
    59                      if(strcmp(c,low[j])==0){
    60                         num+=j;
    61                        break;
    62                    }
    63           }
    64         
    65       printf("%d",num);
    66       if(i!=sum-1) printf("
    ");
    67    }
    68      }
    69     return 0;
    70 }
    View Code
     
  • 相关阅读:
    《真是头铁的》 回复
    今天 凌晨, 我 的 许多 帖子 (回复) 被 反相吧 吧务 删除
    《【建议】吧务同志们每个礼拜写一篇规范论文》 回复
    《有个数学模型想咨询下吧友的意见》 回复
    《请大家推荐反相吧大吧主》 回复
    复变函数 和 积分变换 就是 自己 设定 一套规则 自己 玩
    《这是等臂杠杆还是省力杠杆?》 回复
    《我的理论转帖讨论》 回复
    《数学已经明确了,0.999...与1是完全相等的》 回复
    和 @物空必能 的 对话
  • 原文地址:https://www.cnblogs.com/a982961222/p/12364477.html
Copyright © 2020-2023  润新知