奔跑的赵云 发表于 2020-11-10 16:34:58

零基础入门学Python的最后一个操作题

编写一个函数 findstr(),该函数统计一个长度为 2 的子字符串在另一个字符串中出现的次数。例如:假定输入的字符串为“You cannot improve your past, but you can improve your future. Once time is wasted, life is wasted.”,子字符串为“im”,函数执行后打印“子字母串在目标字符串中共出现 3 次”。
def findStr(desStr, subStr):
    count = 0
    length = len(desStr)
    if subStr not in desStr:
      print('在目标字符串中未找到字符串!')
    else:
      for each1 in range(length-1):    ## ----------请问这个为什么是length-1,用length就不行???
            if desStr == subStr:
                if desStr == subStr:
                  count += 1
                  
      print('子字符串在目标字符串中共出现 %d 次' % count)

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

qiuyouzhi 发表于 2020-11-10 16:40:31

因为它下面有一个each+1呀,不减一这里就IndexError了

小甲鱼的铁粉 发表于 2020-11-10 16:40:45

if desStr == subStr:
这里有each1+1,试想一下,如果each1 = length-1,那么each1 + 1就等于length,那么desStr就越界了

笨鸟学飞 发表于 2020-11-10 16:41:17

用length也不是不行啊,他算法就是当前字符和下一个字符,与被匹配的长度为2的字符作比较
你总长度如果用length-1,那么被检索的字符串的索引each+1就不会超出范围
你如果用for each in range(length)
那么你怎么构建算法?要么for each in range(1,length)
每次比较each-1,each,和subStr,subStr
要么就是如果each=length-1的时候跳出循环

jackz007 发表于 2020-11-10 16:42:58

本帖最后由 jackz007 于 2020-11-10 16:44 编辑

      for each1 in range(length-1):    ## ----------请问这个为什么是length-1,用length就不行???
            if desStr == subStr:
                if desStr+1] == subStr:

      是因为红色的标注的地方,如果不用 length-1 当 each1 == length - 1 的时候,each + 1 = length,作为下标就已经越界了。
页: [1]
查看完整版本: 零基础入门学Python的最后一个操作题