PAT1014 福尔摩斯的约会

大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 3485djDkxh4hhGE 2984akDfkkkkggEdsb s&hgsfdk d&Hyscvnm”。大侦探很快就明白了,字条上奇怪的乱码实际上就是约会的时间“星期四 14:04”,因为前面两字符串中第1对相同的大写英文字母(大小写有区分)是第4个字母’D’,代表星期四;第2对相同的字符是’E’,那是第5个英文字母,代表一天里的第14个钟头(于是一天的0点到23点由数字0到9、以及大写字母A到N表示);后面两字符串第1对相同的英文字母’s’出现在第4个位置(从0开始计数)上,代表第4分钟。现给定两对字符串,请帮助福尔摩斯解码得到约会的时间。

输入格式:

输入在4行中分别给出4个非空、不包含空格、且长度不超过60的字符串。

输出格式:

在一行中输出约会的时间,格式为“DAY HH:MM”,其中“DAY”是某星期的3字符缩写,即MON表示星期一,TUE表示星期二,WED表示星期三,THU表示星期四,FRI表示星期五,SAT表示星期六,SUN表示星期日。题目输入保证每个测试存在唯一解。

输入样例:
3485djDkxh4hhGE
2984akDfkkkkggEdsb
s&hgsfdk
d&Hyscvnm
输出样例:
THU 14:04
解题思路:其实就是基本的字符串的操作,但是将代码和在一起会很繁琐而且容易出错,分模块来写。

一,字符变星期

string letter2week(char tag){
    string week[7] = { "MON", "TUE", "WED", "THU", "FRI", "SAT", "SUN" };
    int t = int(tag) - 64;
    return week[t - 1];
}

二,字符变小时

int letter2hour(char tag){
    int t = (int)tag - 64 + 9;
    return t;
}

三,比较前两串

char *findWeek(string str1,string str2){
    char tag[2];
    bool flag1 = false;
    int len1 = str1.length(),len2=str2.length(),c=1,k1=0,k2=0;
    for (int i = 0; i < len1; ++i){
        tag[0] = str1[i];
        if (isupper(tag[0]))
        {
            for (int j = 0; j < len2; ++j){
                if (str2[j] == tag[0]){ flag1 = true; ++c; k1 = i;k2=j; break; }
            }
        }
        if (flag1)break;
    }
    flag1 = false;
    if (c == 2){
        for (int i = k1+1; i < len1; ++i){
            tag[1] = str1[i];
            if (isupper(tag[1]))
            {
                for (int j = k2+1; j < len2; ++j){
                    if (str2[j] == tag[1]){ flag1 = true; ++c; k1 = i; k2 = j; break; }
                }
            }
            if (flag1)break;
        }
    }

    return tag;
}

四,比较后两串

int findMins(string str1, string str2){
    char tag;
    int len1 = str1.length(), len2 = str2.length(),k=0;
    bool flag = false;
    for (int i = 0; i < len1; ++i){
        tag = str1[i];
        if (isalpha(tag)){
            for (int j = 0; j < len2; ++j){
                if (tag == str2[j]){ k = j; flag = true; k = j; break; }
            }
        }
        if (flag)break;
    }
    return k;
}

五,主程序

int main(){
    string str1 = "3485djDkxh4hhGE", str2 = "2984akDfkkkkggEdsb";
    string str3 = "s&hgsfdk", str4 = "d&Hyscvnm";
    char *tag;
    tag = findWeek(str1, str2);
    char week = tag[0], hour = tag[1];
    cout <<letter2week(week) << " " << letter2hour(hour)<< ":";
    int mins = findMins(str3, str4);
    if (mins < 10)cout << "0" << mins << endl;
    else cout << mins << endl;
    return 0;
}
                   第二种方法
int funs(char x){
    int result = 0;
    if (x >= '0'&&x <= '9')result = (x - '0');
    if (x >= 'A'&&x <= 'N')result = (x - 'A') + 10;
    return result;
}
void PATexe(){
    string str[4] = {"3485djDkxh4hhGE", "2984akDfkkkkggEdsb", "s&hgsfdk", "d&Hyscvnm"};
    string week[7] = { "MON", "THE", "WED", "THU", "FRI", "SAT", "SUN" };
    int lenstr[4] = { 0 },k=0;
    char tmp[2];

    bool a = false,b=false;
    for (int i = 0; i < 4; ++i){
        lenstr[i] = str[i].length();
    }
    for (int i = 0; i < lenstr[0]; ++i){
        if (!isupper(str[0][i]))continue;
        for (int j = 0; j < lenstr[1]; ++j){        
            if (str[0][i] == str[1][j] && isupper(str[0][i]) ){ tmp[k++] = str[0][i];}
        }
    }
    cout << week[tmp[0] - 'A'] << " ";
    k = funs(tmp[1]);
    k<10 ? cout << '0' << k : cout << k;
    cout <<':';

    k = 0;
    while (k<lenstr[2])
    {
        if (str[2][k] == str[3][k]&&isalpha(str[2][k])){ break; }
        else ++k;
    }
    k<10 ? cout << '0' << k : cout << k;
    cout << endl;
}

你可能感兴趣的:(C++,pat)