鱼C论坛

 找回密码
 立即注册
查看: 1861|回复: 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
[b]

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

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

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

参考代码:
str1 = ''' 拷贝过来的字符串 '''

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

    for i in range(3, length-4):
        if Str[i].islower():
            if Str[i - 3: i].isupper():
                if Str[i - 4].islower():
                    if Str[i + 1: i + 4].isupper():
                        if Str[i + 4].islower():
                            str1 += Str[i]
    return str1

print(Find(str1))
[/b]
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

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

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


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

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

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

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

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

    """
    |如果str1[i]是小写字母:
    |-- 如果小写字母前边不是三个大写字母(不符合条件):
    |-- -- 清空所有记录,重新统计
    |-- 如果小写字母前边是三个大写字母(符合条件):
    |-- -- 如果已经存在小写字母:
    |-- -- -- 清空所有记录,重新统计(出现两个小写字母)
    |-- -- 如果该小写字母是唯一的:
    |-- -- -- countB记录出现小写字母,准备开始统计countC
    """
    if str1[i].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[i+1].isupper():
            countB = 0
            countC = 0
        else:
            print(str1[target], end='')
            countA = 3
            countB = 0
            countC = 0
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

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

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

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

参考代码:
str1 = ''' 拷贝过来的字符串 '''

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

    for i in range(3, length-4):
        if Str[i].islower():
            if Str[i - 3: i].isupper():
                if Str[i - 4].islower():
                    if Str[i + 1: i + 4].isupper():
                        if Str[i + 4].islower():
                            str1 += Str[i]
    return str1

print(Find(str1))
[/b]
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-15 13:50

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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