大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 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表示星期日。题目输入保证每个测试存在唯一解。

输入样例

1
2
3
4
3485djDkxh4hhGE 
2984akDfkkkkggEdsb
s&hgsfdk
d&Hyscvnm

输出样例

1
THU 14:04

代码实现

C语言

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
#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;
}