尿尿地方不可以 发表于 2022-6-16 21:06:42

第18讲课后题

题目如图,我自己用两种方法写了这个代码,一种是for循环字符位置,这个代码没有问题。另一种是for循环字符,这个就出问题了
def findstr():
    temp = input('请输入目标字符串:')
    letter = input('请输入子字符串:')
    count = 0
    for each in temp:
      if each+temp == letter:
            count += 1
    print('子字符串在目标字符串中共出现',count,'次')
    return count

当我输入You cannot improve your past, but you can improve your future. Once time is wasted, life is wasted.然后查找im,结果返回的是6,我不明白这6个是怎么出来的

尿尿地方不可以 发表于 2022-6-16 21:09:11

还有就是这个代码有个bug,就是for循环到了最后一个字符,代码还检查最后一个字符后面位置的不存在的字符(temp),那代码为什么没有报错反而输出了结果

尿尿地方不可以 发表于 2022-6-16 21:23:13

这个是我另一个方法写的没啥问题

def findstr1():
    temp = input('请输入目标字符串:')
    letter = input('请输入子字符串:')
    count = 0
    length = len(temp)
    for each in range(length-1):
      if temp + temp == letter:
            count += 1
    print('子字符串在目标字符串中共出现', count, '次')
    return count

森亦简 发表于 2022-6-17 00:27:40

本帖最后由 森亦简 于 2022-6-17 00:28 编辑

原因是str.index()这个指令,当有多个相同的元素只会返回第一个的下标。虽然你设置成了去找each的下标然后+1,但是对于这个指令而言,不管你是输入最先出现的12号位置的i,还是输入别的位置的i,对于后面的来说temp.index(each)始终等于最先出现i得位置12,加1之后自然是m。也就是说后面出现所有的i,随之temp这个的结果都是m,刚好这句话里有6个i所以你的答案出现了6次的结果。

尿尿地方不可以 发表于 2022-6-17 06:59:23

森亦简 发表于 2022-6-17 00:27
原因是str.index()这个指令,当有多个相同的元素只会返回第一个的下标。虽然你设置成了去找each的下标然 ...

明白了,谢谢大佬
页: [1]
查看完整版本: 第18讲课后题