PAT A1100

PAT A1100_第1张图片
实质上没什么难的,体感表达的意思无非是将十进制数字转换为13进制,然后给出将数字替换成相应的字符串;

但是这道题的示例代码给出了所谓打表的新思路,之前没参加过ACM或者OJ比赛,也就没听说过;
简单的来说就是对可能的输出结果进行计算,在输入值的时候可以直接按表输出,减少了不必要的重复计算;

对于代码里,有scanf("%d%*c",&T);
其第二个输入的目的是跳过输入;
个人认为其根本目的就是为了清除T后面的换行符;
利用getchar()也可以清除换行符,这里需要注意一下;
详细代码如下所示:

#include
#include
#include
#include
#include
using namespace std;
using std::map;
string unitDigit[13]={"tret","jan", "feb", "mar", "apr", "may", "jun", "jly", "aug", "sep", "oct", "nov", "dec"};
string tenDigit[13]={"tret","tam", "hel", "maa", "huh", "tou", "kes", "hei", "elo", "syy", "lok", "mer", "jou"};
string numToStr[170];
mapStrToNum;
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

你可能感兴趣的:(PAT A1100)