鱼C论坛

 找回密码
 立即注册
查看: 1628|回复: 3

[已解决]python第二讲作业求组

[复制链接]
发表于 2021-6-8 20:38:59 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
1. 请用已学过的知识编写程序,找出小甲鱼藏在下边这个长字符串中的密码,密码的埋藏点符合以下规律:Y5d|MAp
Y5d|MAp
    a) 每位密码为单个小写字母Powered by bbs.fishc.com
    b) 每位密码的左右两边均有且只有三个大写字母qH{]*ZR

求助各位大神,为什么我这样写不行,得不到正确的答案呀 :
str1 = """拷贝来的字符串"""


def Find(Str):
    str1 = ""
    length = len(Str)

    for i in range(3, length-3):
        if Str[i] == "\n":
            continue
        if i == 3 or i == length-3:
            if Str[i].islower():
                if Str[i-3: i-1].isupper():
                    if Str[i+1: i+3].isupper():
                        str1 += Str[i]
        else:
            if Str[i].islower():
                if Str[i-3: i-1].isupper():
                    if Str[i-4].islower():
                        if Str[i+1: i+3].isupper():
                            if Str[i+4].islower():
                                str1 += Str[i]
            
        
               

    return str1


print(Find(str1))
最佳答案
2021-6-8 21:00:43


切片索引内容包含左索引不包含右索引,所以 Str[i-3: i-1] 这里的 -1 不需要 ,Str[i+1: i+3] 这里 i + 3 应该改成 +4

另外 for 循环中可以不用分两种情况,因为你在 for 循环中设置了开始值、减去了最终长度,但是最终长度应该减去错误,应该为 4 因为 len 函数总比索引值 大 1

for 循环中的 if 判断是否为 \n 也不需要,况且这样判断也无法避免 \n 被算入前三或后三的字符中去,应该在 字符串遍历前将 \n 除去

参考代码:

  1. str1 = ''' 拷贝过来的字符串 '''

  2. def Find(Str):
  3.     Str = Str.replace('\n','')
  4.     str1 = ""
  5.     length = len(Str)

  6.     for i in range(3, length-4):
  7.         if Str[i].islower():
  8.             if Str[i - 3: i].isupper():
  9.                 if Str[i - 4].islower():
  10.                     if Str[i + 1: i + 4].isupper():
  11.                         if Str[i + 4].islower():
  12.                             str1 += Str[i]
  13.     return str1

  14. print(Find(str1))
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-6-8 20:45:52 | 显示全部楼层
本帖最后由 fc5igm 于 2021-6-8 21:10 编辑

你的问题:
str1 = """拷贝来的字符串"""
str1 = ""

你把第一个拷贝来的字符串那个变量,先换成Str1试试


我写的答案
  1. stri='''(那堆字符)'''
  2. ver1=0
  3. ps=[]
  4. for i in range(3,len(stri)-3):
  5.     if stri[i].islower():
  6.         for n in [-3,-2,-1,1,2,3]:
  7.             if stri[i+n].isupper():
  8.                 ver1+=1
  9.         if ver1==6:
  10.             if (stri[i-4].isupper()==False if i-4>=0 else True) and stri[i+4].isupper()==False:
  11.                 ps.append(stri[i])
  12.         ver1=0
  13. ps=''.join(ps)
  14. print('密码是:',ps)
复制代码


小甲鱼的答案
  1. str1 = '''ABSaDKSbRIHcRHGcdDIF'''

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

  6. for i in range(length):
  7.     if str1[i] == '\n':
  8.         continue

  9.     """
  10.     |如果str1[i]是大写字母:
  11.     |-- 如果已经出现小写字母:
  12.     |-- -- 统计后边的大写字母
  13.     |-- 如果未出现小写字母:
  14.     |-- -- 清空后边大写字母的统计
  15.     |-- -- 统计前边的大写字母
  16.     """
  17.     if str1[i].isupper():
  18.         if countB:
  19.             countC += 1
  20.         else:
  21.             countC = 0
  22.             countA += 1

  23.     """
  24.     |如果str1[i]是小写字母:
  25.     |-- 如果小写字母前边不是三个大写字母(不符合条件):
  26.     |-- -- 清空所有记录,重新统计
  27.     |-- 如果小写字母前边是三个大写字母(符合条件):
  28.     |-- -- 如果已经存在小写字母:
  29.     |-- -- -- 清空所有记录,重新统计(出现两个小写字母)
  30.     |-- -- 如果该小写字母是唯一的:
  31.     |-- -- -- countB记录出现小写字母,准备开始统计countC
  32.     """
  33.     if str1[i].islower():
  34.         if countA != 3:
  35.             countA = 0
  36.             countB = 0
  37.             countC = 0
  38.         else:
  39.             if countB:
  40.                 countA = 0
  41.                 countB = 0
  42.                 countC = 0
  43.             else:
  44.                 countB = 1
  45.                 countC = 0
  46.                 target = i

  47.     """
  48.     |如果前边和后边都是三个大写字母:
  49.     |-- 如果后边第四个字母也是大写字母(不符合条件):
  50.     |-- -- 清空记录B和C,重新统计
  51.     |-- 如果后边仅有三个大写字母(符合所有条件):
  52.     |-- -- 打印结果,并清空所有记录,进入下一轮统计
  53.     """
  54.     if countA == 3 and countC == 3:
  55.         if i+1 != length and str1[i+1].isupper():
  56.             countB = 0
  57.             countC = 0
  58.         else:
  59.             print(str1[target], end='')
  60.             countA = 3
  61.             countB = 0
  62.             countC = 0
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-6-8 21:00:43 | 显示全部楼层    本楼为最佳答案   


切片索引内容包含左索引不包含右索引,所以 Str[i-3: i-1] 这里的 -1 不需要 ,Str[i+1: i+3] 这里 i + 3 应该改成 +4

另外 for 循环中可以不用分两种情况,因为你在 for 循环中设置了开始值、减去了最终长度,但是最终长度应该减去错误,应该为 4 因为 len 函数总比索引值 大 1

for 循环中的 if 判断是否为 \n 也不需要,况且这样判断也无法避免 \n 被算入前三或后三的字符中去,应该在 字符串遍历前将 \n 除去

参考代码:

  1. str1 = ''' 拷贝过来的字符串 '''

  2. def Find(Str):
  3.     Str = Str.replace('\n','')
  4.     str1 = ""
  5.     length = len(Str)

  6.     for i in range(3, length-4):
  7.         if Str[i].islower():
  8.             if Str[i - 3: i].isupper():
  9.                 if Str[i - 4].islower():
  10.                     if Str[i + 1: i + 4].isupper():
  11.                         if Str[i + 4].islower():
  12.                             str1 += Str[i]
  13.     return str1

  14. print(Find(str1))
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-6-8 23:50:38 | 显示全部楼层
懂了,谢谢各位~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-23 00:00

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表