福尔摩斯的约会
题目描述
大侦探福尔摩斯接到一张奇怪的字条:我们约会吧! 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 | 3485djDkxh4hhGE |
输出样例
1 | THU 14:04 |
问题解决:
解题思想及误点剖析
此题难点在于理解题意,有三个重要问题需要我们明确:
- 第 1 对相同的大写英文字母,注意是大写英文字母
- 第 2 对相同的字符,注意由后面的叙述可知,第二对相同的字符应是在第一对相同的大写英文字母基础上的第二对,而且必须是数字字符或大写的英文字母
- 第 1 对相同的英文字母,注意此处要求是英文字母,大写小写均可,但是,相等时必须对应为大写或小写(比如
a
与a
相等,A
与A
相等,但a
与A
不相等)
以上3个重要问题在实现与时间对应时应当注意以下几点:
- 第 1 对相同的大写英文字母的字母表顺序i对应星期i(比如A的字母表顺序为1,其对应星期一),我们知道一周也就7天,因此第 1 对相同的大写英文字母的字母范围必须是
A~G
,注意如果在代码的if条件中,寻找第 1 对相同的大写英文字母的条件是str[0][i] >= 'A'&&str[0][i] <= 'G'
则导致评测不通过(某个测试点答案错误) - 第 2 对相同的字符与小时的对应为:一天的 0 点到 23 点由数字 0 到 9、以及大写字母 A 到 N 表示。注意判断大写字母时,范围一定为
A~N
- 第 1 对相同的英文字母,范围是
A~Z
或a~z
- 还要特别注意在输出小时和分钟时,小于10的数字前要补0。这里,我用的是格式控制符
%02d
,%02d
中2
的含义为:输出宽度为2,0
的含义为:宽度不足2时用0填充
注:如果大家是在牛客网的评测系统提交代码,则条件没有那么多限制,大写字母的范围都用A~Z
也不会出错。
我在书写代码时产生了如下错误,包括一些低级错误。比如while循环内少了i++,输出格式控制等错误。最后,请大家看一下下面的这个程序,代码1
在PAT评测系统评测时有一个测试点不通过,代码2
是通过的(代码1
与代码2
的差别已在代码中标出)。请大家思考一下是为什么?
代码1
1 |
|
代码示例(C语言)
代码2
1 |
|
题目来源:PAT乙级1014
作者:CHEN, Yue
单位:浙江大学