PAT乙级-1044. 火星数字(20)-详解+代码

该博客详细介绍了如何将地球数字与火星数字进行互译,特别是针对使用C语言编程时的处理方法。内容包括数制转换、火星文字符判断和字符串处理等关键步骤,特别注意了低位为零的特殊情况处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目:PAT乙级-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

思路:

    这个题目看上去就是一个简单的数制转换,但是由于博主用c语言做的,所以有些复杂了。

    1、首先输入可能包含空格,因此用正则表达式输入,遇到回车符停止(scanf("%[^\n]“),temps),因为多次输入,要先清空缓冲区的回车(getchar())和字符串里面的东西(memset(temps, 0, sizeof(temps)))。

    2、因为输入的不仅有可能是地球数字,还可能是火星文,因此判断是哪一种,采用判断第一个字母的方式

    3、先将火星文存放进两个数组中(高低位),便于按找索引搜索。

    4、若是地球数字,则先进行数制转换为十三进制,然后根据高低位找索引。

    5、若是火星数字,则按照索引找到数字,再将其转换为十进制输出,在提取字符串的时候要加一个'\0'才可以对字符串进行整体操作。

    6、从输入样例中可以看见有个坑就是,若低位为零,火星文只输出高位字母,因此要考虑到输入的火星文是单个的高位字符串或者是输入的地球文转火星文恰好低位为零的情况。


#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#define N 100
int main()
{
	char a[13][5] = { "tret","jan", "feb", "mar", "apr", "may", "jun", "jly", "aug", "sep", "oct", "nov", "dec" };
	char b[12][4] = { "tam", "hel", "maa", "huh", "tou", "kes", "hei", "elo", "syy", "lok", "mer", "jou" };
	char temps[10] = { 0 }, temps1[4], temps2[5];
	char save[N][10] = { 0 };
	int i, j, num, tempnum, tempnum1, tempnum2;
	scanf("%d", &num);
	for (i = 0; i < num; i++)
	{
		memset(temps, 0, sizeof(temps));//清空
		getchar();//先接收回车符
		scanf("%[^\n]", temps);
		if (temps[0] >= '0'&&temps[0] <= '9')//地球文
		{
			tempnum = atoi(temps);
			tempnum1 = tempnum / 13;
			tempnum2 = tempnum % 13;
			if (tempnum1 != 0 && tempnum2 != 0)//两位
			{
				strcpy(save[i], b[tempnum1 - 1]);//索引,要减1
				strcat(save[i], " ");//加空格
				strcat(save[i], a[tempnum2]);//索引
			}
			else//一位
			{
				if (tempnum1 != 0 && tempnum2 == 0)
				{
					strcpy(save[i], b[tempnum1 - 1]);//索引
				}
				else
				{
					strcpy(save[i], a[tempnum2]);//索引
				}
			}
		}
		else//火星文
		{
			if (temps[4] != '\0')//有两位
			{
				strncpy(temps1, temps, 3);
				temps1[3] = '\0';//使字符串结束
				for (j = 0; j < 12; j++)
				{
					if (strcmp(temps1, b[j]) == 0)
					{
						tempnum1 = j + 1;//索引要加1
						break;
					}
				}
				strncpy(temps2, temps + 4, 4);
				if (temps2[3] != '\0')//四位英文
				{
					temps2[4] = '\0';//使字符串结束
				}
				for (j = 0; j < 13; j++)
				{
					if (strcmp(temps2, a[j]) == 0)
					{
						tempnum2 = j;
						break;
					}
				}
				tempnum = tempnum1 * 13 + tempnum2;
				sprintf(save[i], "%d", tempnum);
			}
			else//只有一位
			{
				strncpy(temps2, temps, 4);
				if (temps2[3] != '\0')//四位英文
				{
					temps2[4] = '\0';//使字符串结束
				}
				tempnum1 = 0;//初始化
				for (j = 0; j < 12; j++)
				{
					if (strcmp(temps2, b[j]) == 0)
					{
						tempnum1 = j + 1;//索引要加1
						break;
					}
				}
				tempnum2 = 0;//初始化
				for (j = 0; j < 13; j++)
				{
					if (strcmp(temps2, a[j]) == 0)
					{
						tempnum2 = j;
						break;
					}
				}
				tempnum = tempnum1 * 13 + tempnum2;
				sprintf(save[i], "%d", tempnum);
			}
		}
	}
	for (i = 0; i < num; i++)
	{
		printf("%s\n", save[i]);
	}
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值