第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个是怎么出来的 还有就是这个代码有个bug,就是for循环到了最后一个字符,代码还检查最后一个字符后面位置的不存在的字符(temp),那代码为什么没有报错反而输出了结果 这个是我另一个方法写的没啥问题
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:28 编辑
原因是str.index()这个指令,当有多个相同的元素只会返回第一个的下标。虽然你设置成了去找each的下标然后+1,但是对于这个指令而言,不管你是输入最先出现的12号位置的i,还是输入别的位置的i,对于后面的来说temp.index(each)始终等于最先出现i得位置12,加1之后自然是m。也就是说后面出现所有的i,随之temp这个的结果都是m,刚好这句话里有6个i所以你的答案出现了6次的结果。 森亦简 发表于 2022-6-17 00:27
原因是str.index()这个指令,当有多个相同的元素只会返回第一个的下标。虽然你设置成了去找each的下标然 ...
明白了,谢谢大佬
页:
[1]