大侦探福尔摩斯接到一张奇怪的字条:“我们约会吧! 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
|
输出样例
代码实现
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; }
|