B1044.火星数字

来源:互联网 发布:淘宝宝贝详情文字描述 编辑:程序博客网 时间:2024/04/30 10:34

火星人是以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 "cstdio"#include "iostream"#include "algorithm"#include "map"using namespace std;//[0~12]的火星文string unitDigit[13] = {"tret","jan","feb","mar","apr",                        "may","jun","jly","aug","sep","oct","nov","dec"};//13的[0~12]倍的火星文string tenDigit[13] = {"tret","tam","hel","maa","huh",                       "tou","kes","hei","elo","syy","lok","mer","jou"};string numToStr[170]; //数字->火星文map<string,int> strToNum; //火星文->数字void init(){    for(int i = 0; i < 13; i++)    {        numToStr[i] = unitDigit[i];        strToNum[ unitDigit[i] ] = i;        numToStr[i * 13] = tenDigit[i];        strToNum[ tenDigit[i] ] = i * 13;    }    for(int i = 1; i < 13; i++)    {        for(int j = 1; j < 13; j++)        {            string str = tenDigit[i] + " " + unitDigit[j];            numToStr[i * 13 + j] = str;            strToNum[str] = i * 13 + j;        }    }}int main(){    init(); //打表    int T;    scanf("%d%*c",&T);    while(T--)    {        string str;        getline(cin,str);        if(str[0] >= '0' && str[0] <= '9')        {            int num = 0;            for(int i = 0; i < str.length(); i++)            {                num = num * 10 + (str[i] - '0');            }            cout << numToStr[num] << endl;        }        else        {            cout << strToNum[str] << endl;        }    }    return 0;}
0 0
原创粉丝点击