1014 福尔摩斯的约会

1 篇文章 0 订阅
1 篇文章 0 订阅

求前两个字符串的第一个相同的大写字母,表示星期几

第二对相同的英文字母,表示钟头数

后两对字符串中的第一个相同的英文字母表示时间

题干上的字条不准确只有三个,其实有四个字符串,在输入样例一中有体现

因此,第一对大写字母,好说,但是第二对相同的字符,不是数字就是大写字母肯定

首先求第一对相同的大写英文字符,因为长度不超过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,这是隐含信息)后面查找,范围09和AN以内,字母是看它在字母表中的位置,A的位置为1。

那么也就说得过去了,因为后面没有其他重合的,那么也就是说,下一个相同的就是了,很明显第一个和第二个要合在一起做。就是在循环判断的时候,首先判断大写字母的相等,判断到了之后就接着判断任意字符的相同。。。判断条件的改变问题,用while+if+flag改变条件?

小时或者分钟不满足两位的要记得补零。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值