PAT 1044火星数字的代码实现及易错点分析(C语言)

题目

火星人是以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

实现思路:

整体思路不难,读入数据,判断哪一种数字,匹配并转换输出,主要是一些细节问题。如从例子中可以看出,火星数字并不像地球数字一样10,20这样的两位数后面加0,另外作为火星数字的匹配数组中,必须余留至少一位,存储结尾'\0',否则数据输出会连起来。

代码如下:

扫描二维码关注公众号,回复: 2543327 查看本文章
#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;
}

易错点:

1.火星文10不输出0的情况;

2.scanf和gets连用中间的回车会让第一个gets为空,最后一个漏掉;

3.strcmp和strncmp的用法。

猜你喜欢

转载自blog.csdn.net/bawangtu/article/details/81267666