|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
- def findStr(desStr, subStr):
- count = 0
- length = len(desStr)
- if subStr not in desStr:
- print('在目标字符串中未找到字符串!')
- else:
- for each1 in range(length-1):
- if desStr[each1] == subStr[0]:
- if desStr[each1+1] == subStr[1]:
- count += 1
-
- print('子字符串在目标字符串中共出现 %d 次' % count)
- desStr = input('请输入目标字符串:')
- subStr = input('请输入子字符串(两个字符):')
- findStr(desStr, subStr)
复制代码
要求:编写一个函数 findstr(),该函数统计一个长度为 2 的子字符串在另一个字符串中出现的次数。例如:假定输入的字符串为“You cannot improve your past, but you can improve your future. Once time is wasted, life is wasted.”,子字符串为“im”,函数执行后打印“子字母串在目标字符串中共出现 3 次”。
能不能解释一下代码else以下的部分,我看不懂,还有那个each1是什么
1,each1就是一个变量啊,for遍历range(length-1)里的所有元素,而这每一次遍历的结果都交给each1存储。
2,首先先得遍历整个字符串,然后判断,
由于我们需要判断长度为2的字符串的出现次数,所以length要减1
(不减一的话,一口气遍历到最后一个元素了,就没有下一个元素了)。
然后就是判断,如果each1上的字符和目标字符串的第1(0)个字符相等, 那么就判断下一个是否相等,如果相等的话count就+1.
|
|