PAT (Basic Level) Practice 1044 火星數字 (20分)

火星人是以 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 <iostream>
#include <string>
using namespace std;
string a[13] = {"tret", "jan", "feb", "mar", "apr", "may", "jun", "jly", "aug", "sep", "oct", "nov", "dec"};
string b[13] = {"###", "tam", "hel", "maa", "huh", "tou", "kes", "hei", "elo", "syy", "lok", "mer", "jou"};
string s;
int len;

void fun1(int num) {
	if (num / 13) cout << b[num/13];
	if (num / 13 && num % 13) cout << " ";
	if (num % 13 || num == 0) cout << a[num%13];
}

void fun2() {
	if (s == "tret") {
		cout << 0;
		return ;
	}
	int t1 = 0, t2 = 0;
	string s1, s2;
	s1 = s.substr(0, 3); //獲得字符串s中 從第0位開始的長度爲3的字符串
	if (len > 4) s2 = s.substr(4, 3);
	for(int i = 1; i < 13; i++)
	{
		if (s1 == b[i]) t1 = i;
		if (s1 == a[i] || s2 == a[i]) t2 = i;
	}
	cout << t1 * 13 + t2;
}

int main()
{
	int n;
	cin >> n;
	getchar();
	for(int i = 0; i < n; i++)
	{
		getline(cin,s);
		if (s[0] >= '0' && s[0] <= '9') {
			fun1(stoi(s));
		} else {
			len = s.size();
			fun2();
		}
		cout << endl;
	}
	
	return 0;
}

結果

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章