火星人是以 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
思路:
输入在 [0, 169)之间,则以火星文的形式写最多是两段字符串。先把火星文存在字符串数组里方便后续比较使用。
假如输入是数字,则输入是十进制数,算出对应十三进制的十位和个位,再转换成相应的火星文形式。需要注意火星文如果是13的整数倍,个位不输出零(tret),其他的情况个位都要输出。十位只有在存在时输出,中间的空格只有在十位和个位都需要输出时才应该输出。
假如输入是字母,那么代表是火星文。再进行一次getchar(),如果获取的字符是'\n',说明输入的是0-12的数或者13的整数倍。只需要进行一次转换。如果获取的字符是' ',则该次输入的火星文有两段,需要分别转换成十进制相加。
#include<stdio.h>
#include<string.h>
char ones[13][5]={"tret","jan","feb","mar","apr","may","jun","jly","aug","sep","oct","nov","dec"};
char tens[13][5]={"null","tam","hel","maa","huh","tou","kes","hei","elo","syy","lok","mer","jou"};
int trans(char *s,int istens,int num_10);
int main(void){
int num_10=0,N;
char s[5];
scanf("%d",&N);
for(int i=0;i<N;i++,num_10=0){
scanf("%s",s);
if(s[0]>='0'&&s[0]<='9'){
sscanf(s,"%d",&num_10);
if(num_10/13) printf("%s",tens[num_10/13]);
if(num_10/13&&num_10%13) printf(" ");
if(!(num_10/13&&!(num_10%13))) printf("%s",ones[num_10%13]);
printf("\n");
}else if(getchar()==' '){
num_10=trans(s,1,num_10);
scanf("%s",s);
num_10=trans(s,0,num_10);
printf("%d\n",num_10);
}else{
num_10=trans(s,0,num_10);
num_10=trans(s,1,num_10);
printf("%d\n",num_10);
}
}
return 0;
}
int trans(char *s,int istens,int num_10){
if(istens==1){
for(int i=1;i<13;i++){
if(strcmp(tens[i],s)==0) num_10+=i*13;
}
}else{
for(int i=0;i<13;i++){
if(strcmp(ones[i],s)==0) num_10+=i;
}
}
return num_10;
}