鱼C论坛

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

[已解决]关于零基础学习Python 18讲课后习题三的疑问

[复制链接]
发表于 2019-5-30 15:41:56 | 显示全部楼层 |阅读模式

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

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

x
如下 是小甲鱼给出的参考答案,  看着不是很懂。 我试着给每行代码标注了我自己的理解。  从 else 开始的代码,我就看不懂了 。有没有大佬给解释标注下else下面几行代码的含义,并纠正下上面几行代码我理解上的谬误。  另外建议小甲鱼能不能给参考代码都价格解释性标注, 初学者表示有些 语法和命令 不是没学到,就是忘记了,很多时候参考答案也完全看不懂。

2. 编写一个函数 findstr(),该函数统计一个长度为 2 的子字符串在另一个字符串中出现的次数。

def findStr(desStr, subStr):                                    #创建一个函数
    count= 0                                                    #赋值count=0
    length = len(desStr)                                        #赋值length=len(desstr) 将参数desstr的字符个数赋值给length
    if subStr not in desStr:                                    #条件 如果参数substr没有出现在参数 desstr中
        print('在目标字符串中未找到字符串!')                    #打印未找到字符串
    else:                                                       #或者
        for each1 in range(length-1):                           #each1在 length-1的字符个数以内
            if desStr[each1] == subStr[0]:                      #如果参数desstr
                if desStr[each1+1] == subStr[1]:
                    count += 1
                    
        print('子字符串在目标字符串中共出现 %d 次' % count)

desStr = input('请输入目标字符串:')
subStr = input('请输入子字符串(两个字符):')
findStr(desStr, subStr)
最佳答案
2019-5-30 22:23:14
    else:                                                       #或者
        for each1 in range(length-1):                           #each1在 length-1的字符个数以内
            if desStr[each1] == subStr[0]:                      #如果参数desstr
                if desStr[each1+1] == subStr[1]:
                    count += 1

题目中不是问「该函数统计一个长度为 2 的子字符串在另一个字符串中出现的次数。」那么统计的时候就是遍历主字符串,从第一个字符开始一个一个往后移。如果当前字符和子串的第一个字符相同,那么就判断下一个字符和子串第二个字符是否相同,若两个都满足计数器加1。任意一个条件不满足,就把主字符串的当前位往后移动,接着判断后面的字符。直到都遍历完成。

按着这个思路再看这部分代码

for each1 in range(length-1):   这行each1就是个数,是从0到length-1的数,每次循环自动+1,加到length(不含)退出循环。比如:第一次循环each1=0,第二次=1......【就是主字符串当前位不断向后移动的过程】

然后就是判断,当前位和子串的第一个是否相同,若相同就判断第二位。都满足count(计数器)+1;其中一个不满足,就进行下一次循环
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2019-5-30 22:23:14 | 显示全部楼层    本楼为最佳答案   
    else:                                                       #或者
        for each1 in range(length-1):                           #each1在 length-1的字符个数以内
            if desStr[each1] == subStr[0]:                      #如果参数desstr
                if desStr[each1+1] == subStr[1]:
                    count += 1

题目中不是问「该函数统计一个长度为 2 的子字符串在另一个字符串中出现的次数。」那么统计的时候就是遍历主字符串,从第一个字符开始一个一个往后移。如果当前字符和子串的第一个字符相同,那么就判断下一个字符和子串第二个字符是否相同,若两个都满足计数器加1。任意一个条件不满足,就把主字符串的当前位往后移动,接着判断后面的字符。直到都遍历完成。

按着这个思路再看这部分代码

for each1 in range(length-1):   这行each1就是个数,是从0到length-1的数,每次循环自动+1,加到length(不含)退出循环。比如:第一次循环each1=0,第二次=1......【就是主字符串当前位不断向后移动的过程】

然后就是判断,当前位和子串的第一个是否相同,若相同就判断第二位。都满足count(计数器)+1;其中一个不满足,就进行下一次循环
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2019-7-1 00:41:08 | 显示全部楼层
shuofxz 发表于 2019-5-30 22:23
题目中不是问「该函数统计一个长度为 2 的子字符串在另一个字符串中出现的次数。」那么统计的时候就是 ...

大神 为什么要-1呢  可以解释一下吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-7-1 11:30:52 | 显示全部楼层
Acon 发表于 2019-7-1 00:41
大神 为什么要-1呢  可以解释一下吗

因为子字符串的长度为2,在主字符串中遍历到倒数第二个就可以了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-13 05:59

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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