想摸妹妹大腚 发表于 2020-4-26 20:49:20

这个代码中的length为什么减1?

编写一个函数 findstr(),该函数统计一个长度为 2 的子字符串在另一个字符串中出现的次数。
代码:
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)
红字部分length-1,他为什么要减1呢,range它不应该是左闭合右开的吗?为什么还要减1那字符串里面的最后一个字符不就落下了吗?

zltzlt 发表于 2020-4-26 20:52:24

因为在循环中要获取 desStr 的值,如果一开始设置为 range(length) 就可能会产生下标越界错误

想摸妹妹大腚 发表于 2020-4-26 20:56:25

zltzlt 发表于 2020-4-26 20:52
因为在循环中要获取 desStr 的值,如果一开始设置为 range(length) 就可能会产生下标越界错误

可是range它是左闭合右面是开区间啊,字符串里面最后一个字符取不到啊!

zltzlt 发表于 2020-4-26 21:01:25

想摸妹妹大腚 发表于 2020-4-26 20:56
可是range它是左闭合右面是开区间啊,字符串里面最后一个字符取不到啊!

如果设置为 range(length),desStr 就有可能是 desStr 的最后一个字符,那再 desStr 就越界了

想摸妹妹大腚 发表于 2020-4-26 21:06:15

zltzlt 发表于 2020-4-26 21:01
如果设置为 range(length),desStr 就有可能是 desStr 的最后一个字符,那再 desStr 就 ...

恩知道了从0开始索引的
页: [1]
查看完整版本: 这个代码中的length为什么减1?