小甲鱼python的18讲,第三个动手的操作的问题
编写一个函数 findstr(),该函数统计一个长度为 2 的子字符串在另一个字符串中出现的次数。例如:假定输入的字符串为“You cannot improve your past, but you can improve your future. Once time is wasted, life is wasted.”,子字符串为“im”,函数执行后打印“子字母串在目标字符串中共出现 3 次”。def findstr(num1,num2):
while num2:
if num2 not in num1:
print('在目标字符串中未找到字符串!',end='')
num2 = input('请输入两位字符:')
elif len(num2) != 2:
num2 = input('请输入两位字符:')
else:
print('子字符串在目标字符串中共出现 %d 次' % num1.count(num2))
break
num1 = input('请输入目标字符串;')
num2 = input('请输入子字符串(两个字符):')
findstr(num1,num2)
上边这个是我自己写的,和答案里写的代码得出的结果是一样的
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)
这个是小甲鱼答案里写的
第一个问题:两段代码得出的结果是一样的,我感觉我写的比较简单一点,但是我怕我写的有什么错误,请大佬们帮我看一下,我写的有没有什么错误,或者其它的问题。
第二个问题:小甲鱼代码,函数体里for循环 “for each1 in range(length-1):” 这段,为什么目标字符串的长度需要 -1 呢?我试了一下,不 -1 的话也是没有问题的,没想明白,请大佬帮我解释一下,老弟先谢啦!
写在最后的:最近学python总是遇到问题,还总麻烦论坛里的各位大佬,真是发自真心的感谢,感谢大家的默默付出,无以为报,只能说:世界因有你更精彩! 本帖最后由 永恒的蓝色梦想 于 2020-5-16 11:25 编辑
1.你这完全是用的BIF,没有意义
2.findStr('79888887771','17') 试试报不报错 本帖最后由 有谁懂 于 2020-5-16 11:46 编辑
回答下第二个问题:小甲鱼的思路是把长字符串的第n-1个字符与短字符串的第一个字符比较,如果相同,再把长字符串的第n个字符与短字符串的第二个字符比较,如果相同就计数一次。因此,最后一次比较时,是把倒数第2个字符先拿出来和短字符串的第一个字符比较,因此length要减一。
关于第1个问题:你的代码用了BIF因此简单些,小甲鱼的没用BIF就复杂点。但你要注意.count这个函数到底是怎么工作的。
求最佳{:10_301:} 1.小甲鱼练习是想叫你用自己的思维来统计出这些数据,而你直接用了count函数,练习效果下降
2.-1是为了防止下面desStr 索引超出范围,比如你正好遍历到range的最后一个数,如果在+1,desStr 就索引不到了~
我去跑了下你和小甲鱼的代码:
如果长字符串为:88888
短字符串为:88
那么你用count函数得到的结果为:2
而小甲鱼的方法结果为:5
现在,你知道你们方法之间的差异了吧。 有谁懂 发表于 2020-5-16 11:45
我去跑了下你和小甲鱼的代码:
如果长字符串为:88888
短字符串为:88
欸? 这个方法有意思, 但是为什么结果会是5呢? 短字符是88的话结果应该是4才合理吧?
页:
[1]