月半三木 发表于 2021-6-7 22:31:11

课后作业

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)
这一段的else后面,为什么是for each1,一般不是用的for each in吗,还有后面的Length-1是什么意思啊,包括后面的each1,我知道他想表达的是指字符串里面的每一个字母,each1+1表示上一个字母的下一个,但是这种表达,感觉不能理解。

起个啥名 发表于 2021-6-7 22:33:13


-1是防止each1+1超出索引值吧,each1是列表切片

Twilight6 发表于 2021-6-7 22:36:42


因为字符串 length 值为你的原字符串总长度,而 for 循环中 通过两个 if 判断是否等于需要替换的字符

desStr 是指此时 for 循环索引到的第一个字符,desStr 指第二个

length - 1 就是为了防止 for 循环到末尾字符时,each1+1 大于 length 即超出字符串总长度二导致报错

页: [1]
查看完整版本: 课后作业