鱼C论坛

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

[已解决]python 018:函数 帮我看下下面的

[复制链接]
发表于 2018-8-8 15:39:27 | 显示全部楼层 |阅读模式

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

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

x
def findStr(desStr, subStr):
    count = 0
    length = len(desStr)  #这里为什么需要返回一个 len 的值
    if subStr not in desStr:
        print('在目标字符串中未找到字符串!')
    else:
        for each1 in range(length-1):      
            if desStr[each1] == subStr[0]:   #这两个 if 是不是表示目标字符串第一次 比较 和第二次比较?
                if desStr[each1+1] == subStr[1]:
                    count += 1
                    
        print('子字符串在目标字符串中共出现 %d 次' % count)

desStr = input('请输入目标字符串:')
subStr = input('请输入子字符串(两个字符):')
findStr(desStr, subStr)
最佳答案
2018-8-8 15:48:44

def findStr(desStr, subStr):
    count = 0
    length = len(desStr)  
    if subStr not in desStr:
        print('在目标字符串中未找到字符串!')
    else:
        for each1 in range(length-1):          #这里要用到 length 才不会寻找超出范围的东西
            if desStr[each1] == subStr[0]:    # each1 是会增加的,所以是每一个元素跟 subStr[0] 依序比较
                if desStr[each1+1] == subStr[1]:    #如果上述条件成立,再比较它们下一个元素
                    count += 1                                #如果成立才 count += 1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-8-8 15:48:44 | 显示全部楼层    本楼为最佳答案   

def findStr(desStr, subStr):
    count = 0
    length = len(desStr)  
    if subStr not in desStr:
        print('在目标字符串中未找到字符串!')
    else:
        for each1 in range(length-1):          #这里要用到 length 才不会寻找超出范围的东西
            if desStr[each1] == subStr[0]:    # each1 是会增加的,所以是每一个元素跟 subStr[0] 依序比较
                if desStr[each1+1] == subStr[1]:    #如果上述条件成立,再比较它们下一个元素
                    count += 1                                #如果成立才 count += 1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-8-8 15:50:24 | 显示全部楼层
len()的作用是获取字符串的长度,在下面根据索引迭代字符串的时候要用。
第一个if作用是判断子字符串第一个字符与目标字符串哪一个相同,如果相同,
再比较子字符串第二个字符与目标字符串下一个字符是否相同
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-26 00:29

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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