1044 火星数字 (20 分)测试点 1 4

火星人是以 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
测试点1的问题在于输入0的时候的翻译,之前我的代码在输入数字的时候
对转换成13进制的个位和十位做过控制,都是以0为界,大于0就输出,小于等于0就不输出,如(13 130这种13的倍数,个位就不输出这也是测试点4的卡点出)所以在0这个地方要特殊处理

#include
#include
//定义两个二位全局变量数组,存放对应的字符。 
char Gewei [13][5]={"tret","jan","feb","mar","apr","may","jun","jly","aug","sep","oct","nov","dec"};
char Gaowei [13][4]={"","tam","hel","maa","huh","tou","kes","hei","elo","syy","lok","mer","jou"};
void huoxinhua(char*str)//数字化成火星文 ,先将字符数字翻译成整数型 
{	char *p=str;
	int gaowei=0;
	int gewei=0; 
	int sum=0;
	while(*p!='\0')	//求数字字符串大小 
	{
		sum=sum*10+*p-'0';
		p++;//注意p的后移,经常忘掉 
	}
	gaowei=sum/13;//高位大小是sum对13整除,取整数部分 
	gewei=sum%13;//取余数 
	//下面这一块就是题目设置的几个卡点,我说不清楚,自己体会吧。 
	if(gaowei)//高位不等于0
	{
	printf("%s",Gaowei[gaowei]);
	if(!gewei)	printf("\n");
	else		printf(" ");
}
	if(gewei)
	printf("%s\n",Gewei[gewei]);
}
void shuzihua(char*str)//分一个字和两个字 
{	int i; 
	int	sum=0; 
	char diyi[4];
	char dier[5];
	if(strlen(str)==3)//前面把tret这种情况考虑了,这里面只考虑1-12 
	{	for(int i=0;i<3;i++)	dier[i]=str[i];
		dier[3]='\0';
		for(i=1;i<13;i++)
		{
			if(!(strcmp(dier,Gewei[i])))//相等
			{
				sum=i;
			} 
			else if(!(strcmp(dier,Gaowei[i])))
			sum=13*i;
		}
		printf("%d\n",sum);
	}
	else//有两个字 
	{
		for(i=0;i<3;i++)	diyi[i]=str[i];	diyi[3]='\0';
		for(i=4;str[i]!='\0';i++)
		dier[i-4]=str[i];//中间有一个空格 
		dier[i-4]='\0';
		for(i=1;i<13;i++)
		{
			if(!strcmp(diyi,Gaowei[i]))	sum=13*i;
		}
		for(i=1;i<13;i++)
		{
			if(!strcmp(dier,Gewei[i]))	sum+=i;
		}
		printf("%d\n",sum);
	}
}
int main()
{
	char str[9];
	int N;
	int i;
	
	scanf("%d",&N);
	getchar();
	
	for(i=0;i='0'&&str[0]<='9')	huoxinhua(str);//数字化为火星 
		else								shuzihua(str);//火星化作数字 
	}
	
	return 0;
}

你可能感兴趣的:(算法,PAT乙级)