fjsboy 发表于 2022-10-21 23:20:48

关于20课课后作业 有没有大神来个详细解释啊。。。有点不懂。。。

请用已学过的知识编写程序,找出小甲鱼藏在下边这个长字符串中的密码,密码的埋藏点符合以下规律:

    a) 每位密码为单个小写字母
    b) 每位密码的左右两边均有且只有三个大写字母



str1 = '''ABSaDKSbRIHcRHGcdDIF'''

countA = 0# 统计前边的大写字母
countB = 0# 统计小写字母
countC = 0# 统计后边的大写字母
length = len(str1)

for i in range(length):
    if str1 == '\n':
      continue

    """
    |如果str1是大写字母:
    |-- 如果已经出现小写字母:
    |-- -- 统计后边的大写字母
    |-- 如果未出现小写字母:
    |-- -- 清空后边大写字母的统计
    |-- -- 统计前边的大写字母
    """
    if str1.isupper():
      if countB:
            countC += 1
      else:
            countC = 0
            countA += 1

    """
    |如果str1是小写字母:
    |-- 如果小写字母前边不是三个大写字母(不符合条件):
    |-- -- 清空所有记录,重新统计
    |-- 如果小写字母前边是三个大写字母(符合条件):
    |-- -- 如果已经存在小写字母:
    |-- -- -- 清空所有记录,重新统计(出现两个小写字母)
    |-- -- 如果该小写字母是唯一的:
    |-- -- -- countB记录出现小写字母,准备开始统计countC
    """
    if str1.islower():
      if countA != 3:
            countA = 0
            countB = 0
            countC = 0
      else:
            if countB:
                countA = 0
                countB = 0
                countC = 0
            else:
                countB = 1
                countC = 0
                target = i

    """
    |如果前边和后边都是三个大写字母:
    |-- 如果后边第四个字母也是大写字母(不符合条件):
    |-- -- 清空记录B和C,重新统计
    |-- 如果后边仅有三个大写字母(符合所有条件):
    |-- -- 打印结果,并清空所有记录,进入下一轮统计
    """
    if countA == 3 and countC == 3:
      if i+1 != length and str1.isupper():
            countB = 0
            countC = 0
      else:
            print(str1, end='')
            countA = 3
            countB = 0
            countC = 0

jackz007 发表于 2022-10-21 23:28:19

      这个代码不需要那么麻烦,只要根据题目的描述,直接了当地实现就可以。
str1 = <加密字符串>
s , p = 'a' + '' . join(str1 . split('\n')) + 'a' , ''
for k in range(4 , len(s) - 4):
    if s . islower() and s . isupper() and s . islower() and s . isupper() and s . islower() : p += s
print(p)

fjsboy 发表于 2022-10-21 23:45:40

jackz007 发表于 2022-10-21 23:28
这个代码不需要那么麻烦,只要根据题目的描述,直接了当地实现就可以。

看了你的代码更加让我整不会了{:5_100:}{:5_100:}

jackz007 发表于 2022-10-22 00:07:23

本帖最后由 jackz007 于 2022-10-22 01:06 编辑

fjsboy 发表于 2022-10-21 23:45
看了你的代码更加让我整不会了

s = '' . join(str1 . split('\n'))
      这一句的作用是删除加密字符串 str1 中所有的换行符 '\n'。由于 str1 是用三引号定义的跨多行的字符串,在字符串中含有多个换行符 '\n' ,会妨碍密码字符的识别,这一句根据字符串中的 '\n' 对字符串进行分割,然后,再逐段将之拼接在一起,这样,字符串中就不再包含任何的换行符了。
s = 'a' + '' . join(str1 . split('\n')) + 'a'
       由于密码字符的识别条件中有每位密码左右两边均有且只有 3 个大写字母 的特征,意思是,密码两边如果有第 4 个字母存在,那么,这个字母一定是小写字母,所以,第 4 个字母也必须纳入识别条件。但是,在字符串内部,第 4 个字母没有问题,唯独在字符串的首尾,这个字母肯定是不存在的,那么,怎么办呢,难道需要对字符串的首尾单另处理?这样,显然会增加问题的处理难度和复杂性。只要为字符串的首尾各添加一个小写字母 'a',字符串首尾的第 4 个字符就有了,这样,就可以用同样的逻辑、同样的条件,对字符串中的每一位密码字符一查到底了。

       剩下比较大小写字母的语句,以及字符串的提取方法,就不用我再多做解释了吧?

sailboats 发表于 2022-10-29 19:21:52

本帖最后由 sailboats 于 2022-10-29 20:43 编辑

很勉强的写出来了,这题困扰了我一下午。。。{:10_247:}
c = '''加密字符串'''

for i in (range(len(c))):
    list1 =
    n = 0
    if c.islower() and i > 2 and i < len(c) - 3:
      
      for x in list1:
            if i - 4 < 0:
                if c.isupper() and c.islower():
                  n += 1
            elif i + 4 == len(c):
                if c.isupper() and c.islower():
                  n += 1
            
            else:
                if c.isupper() and c.islower() and c.islower():
                  n += 1
      # print(n)
      if n == 6:
            print(c,end='')

阿奇_o 发表于 2022-10-29 23:18:28

要不试试 正则表达式?(今天搞正则魔怔了   {:10_250:}
for i in range(0, len(s), 3):
    m = re.search('{3}({1}){3}', s)
    print(m.group(1) if m else '', end='')

abc

lassiter 发表于 2022-10-31 01:42:11

本帖最后由 lassiter 于 2022-10-31 01:50 编辑

re模块有个re.findall方法,但是有缺陷,匹配过的部分会忽略
页: [1]
查看完整版本: 关于20课课后作业 有没有大神来个详细解释啊。。。有点不懂。。。