路人乙宝 发表于 2021-6-1 14:11:50

零基础Python 第十八讲 不明白

for each1 in range(length-1):    这里为什么要把获取的字符长度减一

                  
2. 编写一个函数 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):      
            if desStr == subStr:
                if desStr == subStr:
                  count += 1
                  
      print('子字符串在目标字符串中共出现 %d 次' % count)

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

灰晨 发表于 2021-6-1 14:33:44

range 是从0开始的,你字符串如果长度是10,那么应该是0-9,即range(0,9),因为0是默认的,可以省略

路人乙宝 发表于 2021-6-1 15:03:29

灰晨 发表于 2021-6-1 14:33
range 是从0开始的,你字符串如果长度是10,那么应该是0-9,即range(0,9),因为0是默认的,可以省略

那为什么要range已经是0-9了在减一不就0-8少一个了吗

灰晨 发表于 2021-6-1 15:05:52

路人乙宝 发表于 2021-6-1 15:03
那为什么要range已经是0-9了在减一不就0-8少一个了吗

。。我的意思是你 length = len(desStr) 这个长度是10,所有要减1,range(0,9)

路人乙宝 发表于 2021-6-1 15:29:18

本帖最后由 路人乙宝 于 2021-6-1 15:30 编辑

灰晨 发表于 2021-6-1 15:05
。。我的意思是你 length = len(desStr) 这个长度是10,所有要减1,range(0,9)

length = len(desStr) 这个长度是10,但后面range(length)获取的 0-9正好十个    减一的话0-8不就少了一个吗

灰晨 发表于 2021-6-1 15:46:58

本帖最后由 灰晨 于 2021-6-1 15:52 编辑

路人乙宝 发表于 2021-6-1 15:29
length = len(desStr) 这个长度是10,但后面range(length)获取的 0-9正好十个    减一的话0-8不就 ...

。。。。。。length = len(desStr) 这个长度是10,后面range(length)就是range(10)啊,它会获取0-10的,所以要减1啊{:10_247:}

Twilight6 发表于 2021-6-1 18:37:58


因为你 for 循环中 第二个 if 中是 desStr

而切片索引最长长度为字符串长度,即 length 变量

而你 for 循环中若不进行 -1 ,那么就会导致 each1 + 1 循环时超出字符串最大索引值导致报错

所以需要在 range 内进行 -1

dragon_xiao 发表于 2021-6-1 19:59:44

楼上正解!!
页: [1]
查看完整版本: 零基础Python 第十八讲 不明白