题目: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;
}