这个代码中的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那字符串里面的最后一个字符不就落下了吗? 因为在循环中要获取 desStr 的值,如果一开始设置为 range(length) 就可能会产生下标越界错误 zltzlt 发表于 2020-4-26 20:52
因为在循环中要获取 desStr 的值,如果一开始设置为 range(length) 就可能会产生下标越界错误
可是range它是左闭合右面是开区间啊,字符串里面最后一个字符取不到啊! 想摸妹妹大腚 发表于 2020-4-26 20:56
可是range它是左闭合右面是开区间啊,字符串里面最后一个字符取不到啊!
如果设置为 range(length),desStr 就有可能是 desStr 的最后一个字符,那再 desStr 就越界了 zltzlt 发表于 2020-4-26 21:01
如果设置为 range(length),desStr 就有可能是 desStr 的最后一个字符,那再 desStr 就 ...
恩知道了从0开始索引的
页:
[1]