1044. 火星数字(20)
时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
CHEN, Yue
火星人是以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
#include<stdio.h>
#include<string.h>
char low[13][5]={"tret","jan","feb","mar","apr","may","jun","jly","aug","sep","oct","nov","dec"};
char high[13][5]={"","tam","hel","maa","huh","tou","kes","hei","elo","syy","lok","mer","jou"};
char ans[100][20];
void NtoH(char str[]){ //数字转换成火星文并输出
int x=0;
for(int i=0;str[i];++i)
x = 10*x + str[i] - '0';
if(x<13) printf("%s",low[x]);
else{
printf("%s",high[x/13]);
if(x%13) printf(" %s",low[x%13]);
}
printf("\n");
}
void HtoN(char str[]){ //火星文转数字并输出
char s[5];
int i,j;
for(i=0;str[i] && str[i]!=' ';++i) s[i]=str[i];
s[i] = 0;
for(j=0;j<13;++j){
if(strcmp(s,low[j])==0) break;
}
if(j<13){ //只有个位
printf("%d\n",j);
return;
}
for(j=1;j<13;++j){
if(strcmp(s,high[j])==0) break;
}
int ans=j*13;
if(str[i]==' '){ //还有一位数
for(++i,j=0;str[i];++i,++j) s[j]=str[i];
s[j] = 0;
for(j=0;j<13;++j){
if(strcmp(s,low[j])==0) break;
}
ans += j;
}
printf("%d\n",ans);
}
int main(){
int N;
char str[101][15];
scanf("%d",&N);
getchar();
for(int i=0;i<N;++i)
gets(str[i]);
for(int i=0;i<N;++i){
if(str[i][0]>='0' && str[i][0]<='9')
NtoH(str[i]);
else
HtoN(str[i]);
}
return 0;
}