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
思路: 定義一個map <string, int> m; 直接将字母-值存入m 中 就可以直接通過火星文查詢對應的值
#include<cstdio>
#include<map>
#include<iostream>
#include<cstring>
#include<string>
using namespace std;
int digit(char *a){
int x = 0;
for(int i = 0; i < strlen(a); i++){
x = x * 10 + a[i] - '0';
}
return x;
}
int main(){
//freopen("input.txt", "r", stdin);
map<string, int> m;
char arr1[13][5] = {"tret", "jan", "feb", "mar", "apr", "may", "jun", "jly", "aug", "sep", "oct", "nov", "dec"};
char arr2[12][4] = {"tam", "hel", "maa", "huh", "tou", "kes", "hei", "elo", "syy", "lok", "mer", "jou"};
for(int i = 0; i < 12; i++){
m[arr1[i]] = i;
m[arr2[i]] = (i+1) * 13;
}
m[arr1[12]] = 12; //将火星文與對應的值 都存入map中
int n;
cin >> n;
getchar();
for(int i = 0; i < n; i++){
char s[8];
int x;
gets(s);
if(s[0] >= '0' && s[0] <= '9'){
int x = digit(s);
if(x < 13){
cout << arr1[x] << endl;
continue;
}
if(x % 13 == 0)cout << arr2[x / 13 - 1] <<endl; //這裡要記得 若是13的整數倍 則後面不輸出0,我剛開始就沒考慮到一直錯
else cout << arr2[x / 13 - 1] << " " << arr1[x % 13] << endl;
}
else{
char *p1 = strtok(s, " "); //這個方法是分離字元串的
char *p2 = strtok(NULL, " ");
int x = m[p1];
if( p2 != NULL) x += m[p2];
cout << x << endl;
}
}
return 0;
}