求前两个字符串的第一个相同的大写字母,表示星期几
第二对相同的英文字母,表示钟头数
后两对字符串中的第一个相同的英文字母表示时间
题干上的字条不准确只有三个,其实有四个字符串,在输入样例一中有体现
因此,第一对大写字母,好说,但是第二对相同的字符,不是数字就是大写字母肯定
首先求第一对相同的大写英文字符,因为长度不超过60个字符串,因此可以随便搞
用第一个字符串为基础进行遍历一遍,然后用第二个字符串为基础遍历一遍,再
选取最小的那个数,得到正确的大写字母
用python比较方便,下面是测试的代码:
s1 = input()
s2 = input()
s3 = input()
s4 = input()
求前两个字符串的第一个大写字母
一般而言,不会出现大写字母交叉的可能
那样做是没办法是说哪一个是第一个大写字母
Cap = 'A'
for c1 in s1:
if c1.isupper(): # 一个判断是否为大写字母
for c2 in s2:
if c1 == c2:
Cap = c1
break
现在求第二对相同的字符,这里如果是英文字母,那么它应该是大写的
注意这是第二对相同的字符,而不是第二对相同的大写字符
flag = True
sameword = 'a'
for c1 in s1:
for c2 in s2:
if c1 == c2:
if flag : # 现在就是第一对字符
flag = False
else : # 现在就是第二对字符了
sameword = c1
break
下面求后面两个字符串的第一个相同字符
sameword2 = 'a'
for c3 in s3:
for c4 in s4:
if c3 == c4:
sameword2 = c3
print(Cap)
print(sameword)
print(sameword2)
然后出现问题了,是不支持中文注释的问题。。。既然它提供了网址,那就看看吧。简单地浏览一下,终于知道如果文件里有非ASCII字符,需要在第一行或第二行指定编码声明。修改的方法是:-*- coding: utf-8 -*-
这里本人试过好多次了,必须是在第一行或是第二行加入这么一句:-*- coding: utf-8 -*-否则无效
注意这个是注释,前面再加上一个#才行
上面的试了一下,根本就是全错了。。。下面进行检查一下,还得一步步来
第一步应该出现一个D,但是现在出现了一个E,不知道是怎么回事,后来明白了,上面的那个break是只能终止内层循环,现在的问题是必须终止所有循环才行,现在就是要找一个能够终止多层循环的这么一种方法,可以用python的循环特性---循环自带else来实现,不只是if有,while和for都有else分支。循环体的else分支触发条件是循环正常结束。如果循环内被break跳出,就不执行else。所以这个逻辑是:如果循环内break了,不触发else,则执行下一句外层循环中的break;如果正常结束,执行else分支里的continue,直接跳转到外层循环的下一轮,跳过了第二个break。
Cap = 'A'
for c1 in s1:
if c1.isupper(): # 一个判断是否为大写字母
for c2 in s2:
if c1 == c2:
Cap = c1
break
else:
continue
break
print(Cap)
最终测试出现D了,非常好。
下面写一个返回星期几的函数,或者不用也行
weekday = "ABCDEFG".find(Cap)+1
就ok了,不不不,它是要英文字符的,还是要进行函数转换
好了,第一阶段完成
现在进行第二阶段,找到第二个相同字符,现在的问题是,它什么都不显示。。。即便它已经定义了初始值了,这说明它已经进行替换了
同样的,它也只能break掉内层循环,无法中断外层循环,还是老样子,else中断一下,试一试:
出现了一个8,按照这么说,8是第一个字符没错,但是我要第二个字符啊?这说明,4是第一个字符,而且和8有了交叉,按照这么说,它是不可能作为条件的,必须是大写字母,我的题意理解错了,但是好改
这回出现了一个a。。。
按理说不会出现a的啊?至少出现一个大写的字母才对啊,奇怪?其实这个a是初始化的a,它根本没赋值。。。为什么,是因为break起作用了,因为有那个判断大小写的那个函数,导致最后的break被提前使用了,因此失败了。解决办法是把break放到内层循环同等缩进的地位。
试一下,是E,成功了
但是题干上说:一天的 0 点到 23 点由数字 0 到 9、以及大写字母 A 到 N 表示,因此必有数字之类的。。。它不可能只有大写字母啊?而且在这里还要写一个返回数字的函数,因为返回数字,这个就好写了:
def GetHour(sameword):
num = "0123456789ABCDEFGNIGKLMN".find(sameword)
return int(num)
试一下,是14,完美。
下面求后面两个字符串的第一个相同的英文字符,是位置相同才行,现在才读明白题,难道。。。之前做的都是错的。。。。
既然是相同的位置,那么就一个循环就行:
sameword2 = 'a'
n = len(s3) if len(s3)>len(s4) else len(s4)
for i in range(0, n):
if s3[i] == s4[i]:
sameword2 = s3[i]
break
print(sameword2)
出现&,早说了是英文字符。。改一下,出现s了,再改一下,出现4了,ok
差不多了,测试一下,下面是完整代码:
#-*- coding: utf-8 -*-
def GetWeekDay(Cap):
num = "ABCDEFG".find(Cap)+1
if num == 1:
return "MON"
elif num == 2:
return "TUE"
elif num == 3:
return "WED"
elif num == 4:
return "THU"
elif num == 5:
return "FRI"
elif num == 6:
return "SAT"
elif num == 7:
return "SUN"
def GetHour(sameword):
num = "0123456789ABCDEFGNIGKLMN".find(sameword)
return int(num)
s1 = input()
s2 = input()
s3 = input()
s4 = input()
# 求前两个字符串的第一个大写字母
# 一般而言,不会出现大写字母交叉的可能
# 那样做是没办法是说哪一个是第一个大写字母
Cap = 'A'
for c1 in s1:
if c1.isupper(): # 一个判断是否为大写字母
for c2 in s2:
if c1 == c2:
Cap = c1
break
else:
continue
break
weekday = GetWeekDay(Cap)
# 现在求第二对相同的字符,这里如果是英文字母,那么它应该是大写的
# 注意这是第二对相同的字符,而不是第二对相同的大写字符
flag = True
sameword = 'a'
for c1 in s1:
if c1.isupper():
for c2 in s2:
if c1 == c2:
if flag : # 现在就是第一对字符
flag = False
else : # 现在就是第二对字符了
sameword = c1
break
else:
continue
break
#print(GetHour(sameword))
# 下面求后面两个字符串的第一个相同的英文字符,是位置相同才行
minute = 0
n = len(s3) if len(s3)>len(s4) else len(s4)
for i in range(0, n):
if s3[i] == s4[i] and s3[i].isalpha():
minute = i
break
print("%s %d:%02d" % (weekday, GetHour(sameword), minute))
仍然是错的,意料之中,因为还有问题没有改呢。
第一个大写字母和第二个大写字母可以组合,不错,下面又改进了代码:
#-*- coding: utf-8 -*-
def GetWeekDay(Cap):
num = "ABCDEFG".find(Cap)+1
if num == 1:
return "MON"
elif num == 2:
return "TUE"
elif num == 3:
return "WED"
elif num == 4:
return "THU"
elif num == 5:
return "FRI"
elif num == 6:
return "SAT"
elif num == 7:
return "SUN"
def GetHour(sameword):
num = "0123456789ABCDEFGNIGKLMN".find(sameword)
return int(num)
s1 = input()
s2 = input()
s3 = input()
s4 = input()
# 第一个大写字母和第二个大写字母可以组合,不错
flag = True
Cap1 = 'a'
Cap2 = 'a'
for c1 in s1:
if c1.isupper():
for c2 in s2:
if c1 == c2:
if flag : # 现在就是第一对字符
Cap1 = c1
flag = False
else : # 现在就是第二对字符了
Cap2 = c1
break
else:
continue
break
# 下面求后面两个字符串的第一个相同的英文字符,是位置相同才行
minute = 0
n = len(s3) if len(s3)>len(s4) else len(s4)
for i in range(0, n):
if s3[i] == s4[i] and s3[i].isalpha():
minute = i
break
print("%s %d:%02d" % (GetWeekDay(Cap1), GetHour(Cap2), minute))
但是,它还是第一个对,其他的都不对,我佛了。。看看网上其他人怎么做的吧。。。
网上说,确定小时的字符是在满足1条件的字母的位置(因为两个字符串第一个相同的字符是8,但题目的陈述的是E,这是隐含信息)后面查找,范围0~9和A~N以内,字母是看它在字母表中的位置,A的位置为1。
那么也就说得过去了,因为后面没有其他重合的,那么也就是说,下一个相同的就是了,很明显第一个和第二个要合在一起做。就是在循环判断的时候,首先判断大写字母的相等,判断到了之后就接着判断任意字符的相同。。。判断条件的改变问题,用while+if+flag改变条件?
小时或者分钟不满足两位的要记得补零。
网友评论