PAT(Basic Level) 1014 福尔摩斯的约会 (20)

大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 3485djDkxh4hhGE 2984akDfkkkkggEdsb s&hgsfdk d&Hyscvnm”。

项目 要求
时间限制 100 ms
内存限制 65536 kB
代码长度限制 8000 B
判题程序 Standard
作者 CHEN, Yue

大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 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

代码实现

C语言

#include <stdio.h>
#include <stdlib.h>

char* read_line() {
    char *string;
    string = (char*)malloc(60 * sizeof(char));
    scanf("%s", string);
    return string;
}

void judgment_1( char *string_1, const char *string_2 ) {
    int i;
    char week[] = "MONTUEWEDTHUFRISATSUN";

    for ( i=0; i<60; i++){
        if ( string_1[i] == string_2[i] ) {
            int day = string_1[i]-'A';
            if ( day>=0 && day<7 ) {
                printf("%c%c%c ", week[3*day], week[3*day+1], week[3*day+2]);
                break;
            }
        }
    }

    i++;    // 移动i到下一个,否则还是之前找到的那对大写字母。

    for ( ; i<60; i++ ) {
        if ( string_1[i] == string_2[i] ) {
            if ( string_1[i]-'0'>=0 && string_1[i]-'0'<=9 ) {
                printf("%02d:", string_1[i]-'0');
                break;
            } else if ( string_1[i]-'A'>=0 && string_1[i]-'A'<=14 ) {
                printf("%02d:", string_1[i]-'A'+10);
                break;
            }
        }
    }
}

void judgment_2( const char *string_1, const char *string_2 ) {
    int i;

    for ( i=0; i<60; i++ ) {
        if ( string_1[i] == string_2[i] ) {
            int flag = string_1[i] - 'A';
            if ( flag>=0 && flag<26 ) {
                printf("%02d", i);
                break;
            }
            flag = string_1[i] - 'a';
            if ( flag>=0 && flag<26 ) {
                printf("%02d", i);
                break;
            }
        }
    }
}

int main() {
    char *secret_code_1, *secret_code_2;

    secret_code_1 = read_line();
    secret_code_2 = read_line();
    judgment_1(secret_code_1, secret_code_2);
    free(secret_code_1); free(secret_code_2);

    secret_code_1 = read_line();
    secret_code_2 = read_line();
    judgment_2(secret_code_1, secret_code_2);
    free(secret_code_1); free(secret_code_2);

    return 0;
}