longzhou520 发表于 2020-12-18 21:57:49

为什么 length 要减1

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)

昨非 发表于 2020-12-18 22:01:36

因为要作为索引值使用
def findStr(desStr, subStr):   
    count = 0
    length = len(desStr)
    if subStr not in desStr:
      print('在目标字符串中未找到字符串!')
    else: #这里的条件是字串在目标字符串里
      for each1 in range(length-1): #length为目标字符串的长度,减一刚好是目标串的索引范围
            #而for...in range(n)的语法中,...只是一个循环变量名字而已,叫i,j,k,each,什么都可以,它的取值是range函数规定的,0到n-1;
            # each1就是下面要用到的字符串索引值   
            if desStr == subStr:#这里只不过是比较目标串的各个字符有没有和字串第一个字符相同的,如果相同,进入下一层判断
                if desStr == subStr: #与字串第一个字符匹配后,移到后一位字符进行判断,索引值加一就是后移一位,没什么难理解的
                  count += 1 #前两个条件都满足了,计数出现次数加一
                  
      print('子字符串在目标字符串中共出现 %d 次' % count)
页: [1]
查看完整版本: 为什么 length 要减1