夏夜星空 发表于 2018-1-15 21:44:42

求助18讲最后一个课后习题

def findStr(desStr, subStr):
    count = 0
    length = len(desStr)
    if subStr not in desStr:
      print('在目标字符串中未找到字符串!')
    else:
      for each1 in range(length-1):      
            if desStr == subStr:
                if desStr == subStr:
                  count += 1
                  
      print('子字符串在目标字符串中共出现 %d 次' % count)

desStr = input('请输入目标字符串:')
subStr = input('请输入子字符串(两个字符):')
findStr(desStr, subStr)

这段代码 else:后面的语句块有点不是很能理解

orino 发表于 2018-1-15 21:50:38

后面的语句,进行了子串的匹配,即两次比较,因为子串只有两个字符,所以只要比较两次,第一个字符相同,第二个字符也相同,然匹配成功计数器+1

orino 发表于 2018-1-15 21:52:32

就是对于目标串,从首位开始,和子串第一位比较,成功的话,比较目标串第二位和子串第二位。否则目标串+1,开始比较目标串第2位和子串第二位,以此类推

zero月蚀的假面 发表于 2018-1-15 22:13:15

举个例子:
desStr=‘abcde’,subStr=‘cd’,
length(desStr)=5,下标范围=length-1=4(因为下标是从0开始数的)
desStr=subStr='c',desStr=subStr='d'
计数count += 1

BngThea 发表于 2018-1-16 09:24:57

就是遍历目标字符串,去匹配子字符串,如果满足,那么计数加一
这里有个潜在的bug,遍历范围应该是range(length-2),你自己想想为什么

夏夜星空 发表于 2018-1-16 10:19:02

zero月蚀的假面 发表于 2018-1-15 22:13
举个例子:
desStr=‘abcde’,subStr=‘cd’,
length(desStr)=5,下标范围=length-1=4(因为下标是从 ...

谢谢老哥,有点能理解了。

orino 发表于 2018-1-16 10:36:49

这种代码自己运行一下,多试几个例子可以帮助理解

whdd 发表于 2018-9-19 15:14:32

学习

钱闻韬 发表于 2018-9-19 20:13:10

学习了!!!

2418 发表于 2018-9-19 21:46:04

学习

学学看看 发表于 2018-9-21 13:21:09

心驰神往 发表于 2020-11-28 09:37:24

小古比鱼 发表于 2020-12-10 17:17:20

{:10_254:}
页: [1]
查看完整版本: 求助18讲最后一个课后习题