鱼C论坛

 找回密码
 立即注册
查看: 2098|回复: 2

[已解决]俺又来了 第十八课遇到的问题 谢谢各位

[复制链接]
发表于 2020-2-8 16:32:48 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
2. 编写一个函数 findstr(),该函数统计一个长度为 2 的子字符串在另一个字符串中出现的次数。例如:假定输入的字符串为“You cannot improve your past, but you can improve your future. Once time is wasted, life is wasted.”,子字符串为“im”,函数执行后打印“子字母串在目标字符串中共出现 3 次”。

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)
最佳答案
2020-2-8 16:35:26
想一下,再123中查找长度为2的字符串,需要查找几次,3次吗???
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-2-8 16:35:26 From FishC Mobile | 显示全部楼层    本楼为最佳答案   
想一下,再123中查找长度为2的字符串,需要查找几次,3次吗???
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-2-8 16:35:53 | 显示全部楼层
如果是 for each1 in range(length),each1 就有可能是 length - 1。如果 each1 为 length - 1,则 each1 + 1 就是 length,desStr[each1+1] 访问会越界。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2026-3-3 20:21

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表