火星人是以 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
思路:
首先,由于输入的火星文是包含空格的字符串,因此我们需要想办法把每个数字提取出来,这里用到了函数sscanf(),这里是关于该函数用法的详细介绍:https://blog.csdn.net/gzshun/article/details/7081736 。
代码:
#include<stdio.h>
#include<string.h>
int main(){
char Zero[5]="tret";
char Earth[12][4]={"jan","feb","mar","apr","may","jun","jly","aug","sep","oct","nov","dec"};
char Mars[12][4]={"tam","hel","maa","huh","tou","kes","hei","elo","syy","lok","mer","jou"};
int N;
char number[100][12],buf1[4],buf2[4];
scanf("%d",&N);
getchar();//接收scanf()回车遗留字符
for(int i=0;i<N;i++){
gets(number[i]);
}
for(int i=0;i<N;++i){
int temp,len;
if(number[i][0]>='0'&&number[i][0]<='9'){//地球文
sscanf(number[i],"%d",&temp);
if(temp>=13){
if(temp%13==0){
printf("%s",Mars[temp/13-1]);
}
else
printf("%s %s",Mars[temp/13-1],Earth[temp%13-1]);
}
else{
if(temp==0){
printf("%s",Zero);
}
else
printf("%s",Earth[temp-1]);
}
}
else{//火星文
int j;
len=strlen(number[i]);
if(len<6){
sscanf(number[i],"%s",buf1);
if(!strcmp(Zero,buf1)){
temp=0;
}
else
{
for(j=0;strcmp(buf1,Earth[j])!=0;++j);
temp=j+1;
}
printf("%d",temp);
}
else{
sscanf(number[i],"%s %s",buf1,buf2);
for(j=0;strcmp(buf1,Mars[j])!=0;++j);
temp=13*(j+1);
if(strcmp(Zero,buf2)!=0){
for(j=0;strcmp(buf2,Earth[j])!=0;++j);
temp=temp+j+1;
}
printf("%d",temp);
}
}
if(i!=N-1){
printf("\n");
}
}
return 0;
}
第一次修改:
之前忽略了一个问题,即火星文为一位时,可能是进位了的也可能是未进位的。
#include<stdio.h>
#include<string.h>
int main(){
char Zero[5]="tret";
char Earth[12][4]={"jan","feb","mar","apr","may","jun","jly","aug","sep","oct","nov","dec"};
char Mars[12][4]={"tam","hel","maa","huh","tou","kes","hei","elo","syy","lok","mer","jou"};
int N;
char number[100][12],buf1[4],buf2[4];
scanf("%d",&N);
getchar();//接收scanf()回车遗留字符
for(int i=0;i<N;i++){
gets(number[i]);
}
for(int i=0;i<N;++i){
int temp,len;
if(number[i][0]>='0'&&number[i][0]<='9'){//地球文
sscanf(number[i],"%d",&temp);
if(temp>=13){//会产生进位的地球文
if(temp%13==0){
printf("%s",Mars[temp/13-1]);
}
else
printf("%s %s",Mars[temp/13-1],Earth[temp%13-1]);
}
else{//不会产生进位的地球文
if(temp==0){
printf("%s",Zero);
}
else
printf("%s",Earth[temp-1]);
}
}
else{//火星文
int j;
len=strlen(number[i]);
if(len<6){//只有一位火星文
sscanf(number[i],"%s",buf1);
if(!strcmp(Zero,buf1)){
temp=0;
}
else
{
for(j=0;j<12;++j){
if(strcmp(Earth[j],buf1)==0){//未进位
temp=j+1;
break;
}
if(strcmp(Mars[j],buf1)==0){//有进位
temp=13*(j+1);
break;
}
}
}
printf("%d",temp);
}
else{//有两位火星文
sscanf(number[i],"%s %s",buf1,buf2);
for(j=0;strcmp(buf1,Mars[j])!=0;++j);
temp=13*(j+1);
if(strcmp(Zero,buf2)!=0){
for(j=0;strcmp(buf2,Earth[j])!=0;++j);
temp=temp+j+1;
}
printf("%d",temp);
}
}
if(i!=N-1){
printf("\n");
}
}
return 0;
}