1014 福尔摩斯的约会 (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
这个题呢我的第一反应是建两个字典,分别对应星期几和时间里面的小时
ls=[]
for i in range(4):
x=input()
ls.append(x)
s1=len(ls[0])
s2=len(ls[1])
s3=len(ls[2])
s4=len(ls[3])
lsout=[]
for i in range(s1):
for j in range(s2):
if ls[0][i].isupper() and ls[1][j].isupper():
if ls[0][i]==ls[1][j]: #因为题目要求第一个判断的字母得是大写,所以用isupper()
lsout.append(ls[0][i]) #isipper()返回的是True或者False
for i in range(s3):#这里的if看起来很长,其实就是满足1.是字母(大小写都可),2.字母相同
for j in range(s4): #3.下标号相同
if ls[2][i]==ls[3][j] and i==j and (((ls[2][i]>='A')and(ls[2][i]<='Z'))or\
((ls[2][i]>='a') and (ls[2][i]<='z'))):
lsout.append(i)
Day={'A':'MON','B':'TUE','C':'WED','D':'THU','E':'FRI','F':'SAT','G':'SUN'}
Time={'0':'00','1':'01','2':'02','3':'03','4':'04','5':'05','6':'06','7':'07','8':'08',\
'9':'09','A':'10','B':'11','C':'12','D':'13','E':'14','F':'15','G':'16',\
'H':'17','I':'18','J':'19','K':'20','L':'21','M':'22','N':'23'}
day=Day.get(lsout[0],233)
hour=Time.get(lsout[1],234) #233和234是我随便瞎写的,对这题来说不影响
minute=lsout[2]
if minute<10:
print('{} {}:0{}'.format(day,hour,minute))
else:
print('{} {}:{}'.format(day,hour,minute))
但是检测起来错了2个点,还有一个非零返回,对了3个点,以为是输出的分钟数小于10要加0,但是改了以后也不对
下面代码是BTboay的
a1 = input()
a2 = input()
b1 = input()
b2 = input()
result = []
sum = ["MON","TUE","WED","THU","FRI","SAT","SUN"]
for i in range(min(len(a1),len(a2))):
if (a1[i]==a2[i]) and ('A'<=a1[i]<='G'):
result.append(ord(a1[i])-ord('A')+1)
break
for j in range(i+1,(min(len(a1),len(a2)))):
if (a1[j]==a2[j]) and ('A'<=a1[j]<='N'):
result.append(str(ord(a1[j])-ord('A')+10))
break
elif (a1[j]==a2[j]) and ('0'<=a1[j]<='9'):
result.append('0'+a1[j])
break
for i in range(min(len(b1),len(b2))):
if ('a'<=b1[i]<='z' or 'A'<=b1[i]<='Z') and (b1[i]==b2[i]):
if i<10:
result.append('0'+str(i))
else:
result.append(str(i))
break
print("%s %s:%s"%(sum[result[0]-1],result[1],result[2]))
在第11行,关于i的这种用法我终于弄懂了,在第12行加一局print(i+1)就能明白了
这个博主以前的代码也有类似的用法,当时没看懂(书上没写过,视频里也没看到过)
用题目给的输入样例,第7行的for循环break的时候i=6,所以在11行接着用的时候,i就还是6,而不是一个for循环里的临时变量