每日一题 1014

1014 福尔摩斯的约会

题目描述

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

  • 前面两字符串中第 1 对相同的大写英文字母(大小写有区分)是第 4 个字母 D,代表星期四;
    这里第四是相对于26个字母来说,D在第四。说明大写字母I所在位置第几就是星期几,用I-A+1来表示。
  • 第 2 对相同的字符是 E ,那是第 5 个英文字母,代表一天里的第 14 个钟头(于是一天的 0 点到 23 点由数字 0 到 9、以及大写字母 A 到 N 表示);
    注意:这里第一对相同的字符是8,而给出的样例是E,说明这里相同的字符要在第一个条件之后出现才行。0到9点的表示:当前数字-0,在前面要加0,两位数,10到23点的表示方法:I-A+10.
  • 后面两字符串第 1 对相同的英文字母 s 出现在第 4 个位置(从 0 开始计数)上,代表第 4 分钟。
    相同的字母(大小写都可以)出现的位置,这里是相对于字符串来讲,即第几分钟,小于10的,要在前面加0。

注意:两个字符串中相同位置具有相同字母的对数不止两对,所以在确定小时后一定要跳出循环,不然后面还可能又有一对满足第二个条件的,这就错误了,有一个测试点的陷阱就在这里。

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
#include <iostream>
#include <string>
using namespace std;
void week(int n)
{
switch(n)
{
case 1:cout<<"MON"<<' ';break;
case 2:cout<<"TUE"<<' ';break;
case 3:cout<<"WED"<<' ';break;
case 4:cout<<"THU"<<' ';break;
case 5:cout<<"FRI"<<' ';break;
case 6:cout<<"SAT"<<' ';break;
case 7:cout<<"SUN"<<' ';break;
}
}
int main()
{
string s1,s2,s3,s4;
cin>>s1>>s2>>s3>>s4;
int i=0;
bool flag=false;
while(s1.length()>i&&s2.length()>i)
{
if(s1[i]==s2[i])
{
if(flag)
{
if(s1[i]>='0'&&s1[i]<='9')
{
cout<<'0'<<s1[i]-'0'<<":";
break;
}
else if(s1[i]>='A'&&s1[i]<='N')
{
cout<<s1[i]-'A'+10<<":";
break;
}
}
if(!flag&&s1[i]>='A'&&s1[i]<='G')
{
int n=s1[i]-'A'+1;
week(n);
flag=true;
}
}
i++;
}
i=0;
while(s3.length()>i&&s4.length()>i)
{
if(s3[i]==s4[i]&&(s3[i]>='A'&&s3[i]<='Z'||s3[i]>='a'&&s3[i]<='z'))
{
if(i<10) cout<<0;
cout<<i;
break;
}
i++;
}
return 0;
}
文章目录
  1. 1. 1014 福尔摩斯的约会
    1. 1.1. 题目描述
    2. 1.2. 输入格式:
    3. 1.3. 输出格式:
    4. 1.4. 题目分析
    5. 1.5. C++代码