天天看點

PAT - 乙級 1044 火星救援1044. 火星數字(20)

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;
}