关于小甲鱼第18讲,课后作业 编写一个函数 findstr(),该函数统计一个长度为 2 的字符
这是我写的代码 麻烦大佬帮我看下正确不,我自己试下来功能是一样的:def cishu():
x = input('请输入目标字符串:')
y = input('请输入子字符串(两个字符):')
if y in x:
i =x.count(y)
print('子字符串在目标字符串中共出现',i,'次')
else:
print('未找到子字符串')
然后还有小甲鱼给出的答案看的我是一头雾水,可以帮我解答一下吗?
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)
这个desstr【each1】是个什么意思呢 具体看题目要求,如果没有明确要求你的也说得过去
小甲鱼和你的不同的地方就在于重复部分了
例如目标字符串为 abbbc
子字符串为bb
你的结果就是1,他的结果就是2
答案的思路是遍历目标字符串,如果目标字符串中的某一个字符和子字符串的第一个字符相同,再查看下一个字符是否与子字符串第二个字符相同。
for循环里面循环因子是each1,所以desstr【each1】就是目标字符串的一个对应字符,自然desstr【each+1】就代表下一个字符,两者对应等于subStr【0】和subStr【1】自然就符合题目要求了。 desStr【each1】
def findStr(desStr, subStr):出自这里
调用这个函数时传入的第一个值
for each1 in range(length-1): ---each出自这里是一个数
desStr【each1】就是就是desStr字符串中索引为each1的值啦
页:
[1]