PAT 1014 福尔摩斯的约会 python

1014 福尔摩斯的约会 (20)(20 分)

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

作者: CHEN, Yue
单位: PAT联盟
时间限制: 100ms
内存限制: 64MB
代码长度限制: 16KB

问题分析:
本题主要运用了ASCII码的加减和判断运算
ASCII:
A-Z:65-90
a-z:97-122
0-9:48-57

代码:

wstr1 = input()
wstr2 = input()
mstr1 = input()
mstr2 = input()
rst = []
week = ["MON", "TUE", "WED", "THU", "FRI", "SAT", "SUN"]
for i in range(min(len(wstr1), len(wstr2))):
    if wstr1[i] == wstr2[i] and 65 <= ord(wstr1[i]) <= 71:
        rst.append(week[ord(wstr1[i]) - 65])
        break

for j in range(i + 1, min(len(wstr1), len(wstr2))):
    if wstr1[j] == wstr2[j] and 48 <= ord(wstr1[j]) <= 57:
        rst.append('0' + wstr1[j])
        break
    if wstr1[j] == wstr2[j] and 65 <= ord(wstr1[j]) <= 78:
        rst.append(ord(wstr1[j]) - 55)
        break

for x in range(min(len(mstr1), len(mstr2))):
    if mstr1[x] == mstr2[x] and (65 <= ord(mstr1[x]) <= 90 or 97 <= ord(mstr1[x]) <= 122):
        rst.append(x)
        break
if rst[2] < 10:
    rst[2] = '0' + str(rst[2])
print('{} {}:{}'.format(rst[0], rst[1], rst[2]))

猜你喜欢

转载自blog.csdn.net/qq_42800234/article/details/81562840
今日推荐