您的位置:首页 > 编程语言 > C语言/C++

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

2018-07-29 08:55 477 查看

题目

火星人是以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)区间内的数字 —— 或者是地球文,或者是火星文。

输出格式:

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

输入样例:

[code]4
29
5
elo nov
tam

输出样例:

[code]hel mar
may
115
13

实现思路:

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

代码如下:

[code]#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的用法。

阅读更多
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: