1044 火星数字 (20分))(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>
 
int main()
{
  //两个存储匹配数组务必预留结尾'\0'位,可以把高位的第一位留空,以便和数字匹配
  char szD[13][5]={"tret","jan","feb","mar","apr","may","jun","jly","aug","sep","oct","nov","dec"};
  char szG[13][4]={"","tam","hel","maa","huh","tou","kes","hei","elo","syy","lok","mer","jou"};
  int iNum=0;
  scanf("%d",&iNum);
  getchar();//scanf和gets连用的时候,一定注意scanf后面的回车要去掉
  char szData[iNum][9];
  for(int i=0;i<iNum;i++)
  {
    gets(szData[i]);
  }
  int iSum=0;
  for(int i=0;i<iNum;i++)
  {
    iSum=0;
    //判断为地球数字
    if(szData[i][0]>='0'&&szData[i][0]<='9')
    {
      //得到数字值
      for(int j=0;j<strlen(szData[i]);j++)
      {
        iSum=iSum*10+szData[i][j]-'0';
      }
      //分类输出
      if(iSum/13!=0&&iSum%13!=0)
      {
        printf("%s %s",szG[iSum/13],szD[iSum%13]);
      }
      else if(iSum/13!=0&&iSum%13==0)
      {
      	printf("%s",szG[iSum/13]);
	  }
	  else if(iSum/13==0)
	  {
        printf("%s",szD[iSum%13]);
      }
    }
    else
    {
      //只有一位火星数字的情况
      if(strlen(szData[i])<=4)
      {
        for(int j=0;j<13;j++)
        {
          if(strcmp(szData[i],szD[j])==0)
          {
            iSum=j;
            break;
          }
          else if(strcmp(szData[i],szG[j])==0)
          {
          	iSum=j*13;
          	break;
		  }
        }
      }
      //两位火星数字的情况
      else
      {
        for(int j=0;j<13;j++)
        {
          if(strncmp(szData[i],szG[j],3)==0)//比较前3位,即高位
          {
            iSum+=13*j;
          }
          if(strcmp(&szData[i][4],szD[j])==0)
          {
            iSum+=j;
          }
        }
      }
      printf("%d",iSum);
    }
    if(i!=iNum-1)
    {
      printf("\n");
    }
  }
  return 0;
}
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值