鱼C论坛

 找回密码
 立即注册
查看: 948|回复: 11

[已解决]小甲鱼第18讲第2 题

[复制链接]
发表于 2020-4-28 11:59:08 | 显示全部楼层 |阅读模式

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

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

x
def findStr(desStr, subStr):
    count = 0
    length = len(desStr)
    if subStr not in desStr:
        print('在目标字符串中未找到字符串!')
    else:
        for each1 in range(length-1):           //这里为什么要-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-4-28 14:06:18
牛逼牛逼 发表于 2020-4-28 12:30
所以是关系到语句长度的问题吗

没明白你说的“关系到语句长度的问题”是什么意思。


这个很难理解吗?自己在纸上简单写一下不就知道了?
假如目标字符串是"abcdefg",子字符串是"ab"
条件中没有减一的情况下,length=7,each循环赋值分别为:0 1 2 3 4 5 6
第一次循环的时候,比较的desStr下标分别是0  1
第二次循环的时候,比较的desStr下标分别是1  2
……
当each1=6 的时候,循环内的第二个if语句就成了if desStr[7] == subStr[1]:,这不就越界了吗?desStr最大下标是6哎~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-4-28 12:07:19 | 显示全部楼层
因为要比较的字符是两个
循环到倒数第二个的时候,实际上是比较的是最后两个字符。
所以这里需要减一

再者,for循环内有each1+1,若for条件中没有减一。那么当each1是最后一个的时候,each1+1就查出范围了,会报出下标异常的错误。所以条件中必须减一
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-28 12:09:24 | 显示全部楼层
因为后面语句的要加1:if desStr[each1+1] == subStr[1]:,这一句是检查第二个字符,如果前面不减1,最后一次到这里否则会报out of range的错误。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-28 12:30:34 From FishC Mobile | 显示全部楼层
sunrise085 发表于 2020-4-28 12:07
因为要比较的字符是两个
循环到倒数第二个的时候,实际上是比较的是最后两个字符。
所以这里需要减一

所以是关系到语句长度的问题吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-28 12:48:45 | 显示全部楼层
txxcat 发表于 2020-4-28 12:09
因为后面语句的要加1:if desStr[each1+1] == subStr[1]:,这一句是检查第二个字符,如果前面不减1,最后一 ...

大佬,这个是不是关系到语句的长度,如果语句的长度为100是不是不用担心这个问题
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-28 12:49:43 | 显示全部楼层
sunrise085 发表于 2020-4-28 12:07
因为要比较的字符是两个
循环到倒数第二个的时候,实际上是比较的是最后两个字符。
所以这里需要减一

大佬,这个是不是关系到语句的长度,如果语句的长度为100是不是不用担心这个问题
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-28 13:09:41 | 显示全部楼层
牛逼牛逼 发表于 2020-4-28 12:48
大佬,这个是不是关系到语句的长度,如果语句的长度为100是不是不用担心这个问题

没任何关系,for each1 in range(length-1),是从第一个字符遍历到倒数第二个字符,不在乎字符串长度,理论上,只要电脑内存能容纳,想要多长都可以,但是,必须减1才能保证后面的each1+1在最后一次循环不会出错。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-28 14:06:18 | 显示全部楼层    本楼为最佳答案   
牛逼牛逼 发表于 2020-4-28 12:30
所以是关系到语句长度的问题吗

没明白你说的“关系到语句长度的问题”是什么意思。


这个很难理解吗?自己在纸上简单写一下不就知道了?
假如目标字符串是"abcdefg",子字符串是"ab"
条件中没有减一的情况下,length=7,each循环赋值分别为:0 1 2 3 4 5 6
第一次循环的时候,比较的desStr下标分别是0  1
第二次循环的时候,比较的desStr下标分别是1  2
……
当each1=6 的时候,循环内的第二个if语句就成了if desStr[7] == subStr[1]:,这不就越界了吗?desStr最大下标是6哎~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-28 15:19:37 | 显示全部楼层
sunrise085 发表于 2020-4-28 14:06
没明白你说的“关系到语句长度的问题”是什么意思。

牛逼大佬,不好意思,我有点笨
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-4-28 17:29:06 | 显示全部楼层
sunrise085 发表于 2020-4-28 14:06
没明白你说的“关系到语句长度的问题”是什么意思。

def xunzhao(a):
    b = temp.count(a)
    return b
temp = input('请输入目标字符串:')
a = input('请输入子字符串(两个字符):')
print('子字符串在目标字符串中共出现'+ str(xunzhao(a))+ '次' )
你好大佬,我做出了一个简单一点的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-28 17:35:46 | 显示全部楼层
牛逼牛逼 发表于 2020-4-28 17:29
def xunzhao(a):
    b = temp.count(a)
    return b

这个题目就是为了不用count函数,
你用count,那这个题目就没意义了
temp = input('请输入目标字符串:')
a = input('请输入子字符串(两个字符):')
print('子字符串在目标字符串中共出现',temp.count(a), '次' )
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-26 22:31

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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