小甲鱼第18讲第2 题
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 == subStr:
if desStr == subStr:
count += 1
print('子字符串在目标字符串中共出现 %d 次' % count)
desStr = input('请输入目标字符串:')
subStr = input('请输入子字符串(两个字符):')
findStr(desStr, subStr)
复制代码 因为要比较的字符是两个
循环到倒数第二个的时候,实际上是比较的是最后两个字符。
所以这里需要减一
再者,for循环内有each1+1,若for条件中没有减一。那么当each1是最后一个的时候,each1+1就查出范围了,会报出下标异常的错误。所以条件中必须减一 因为后面语句的要加1:if desStr[each1+1] == subStr:,这一句是检查第二个字符,如果前面不减1,最后一次到这里否则会报out of range的错误。 sunrise085 发表于 2020-4-28 12:07
因为要比较的字符是两个
循环到倒数第二个的时候,实际上是比较的是最后两个字符。
所以这里需要减一
所以是关系到语句长度的问题吗 txxcat 发表于 2020-4-28 12:09
因为后面语句的要加1:if desStr == subStr:,这一句是检查第二个字符,如果前面不减1,最后一 ...
大佬,这个是不是关系到语句的长度,如果语句的长度为100是不是不用担心这个问题 sunrise085 发表于 2020-4-28 12:07
因为要比较的字符是两个
循环到倒数第二个的时候,实际上是比较的是最后两个字符。
所以这里需要减一
大佬,这个是不是关系到语句的长度,如果语句的长度为100是不是不用担心这个问题 牛逼牛逼 发表于 2020-4-28 12:48
大佬,这个是不是关系到语句的长度,如果语句的长度为100是不是不用担心这个问题
没任何关系,for each1 in range(length-1),是从第一个字符遍历到倒数第二个字符,不在乎字符串长度,理论上,只要电脑内存能容纳,想要多长都可以,但是,必须减1才能保证后面的each1+1在最后一次循环不会出错。 牛逼牛逼 发表于 2020-4-28 12:30
所以是关系到语句长度的问题吗
没明白你说的“关系到语句长度的问题”是什么意思。
这个很难理解吗?自己在纸上简单写一下不就知道了?
假如目标字符串是"abcdefg",子字符串是"ab"
条件中没有减一的情况下,length=7,each循环赋值分别为:0 1 2 3 4 5 6
第一次循环的时候,比较的desStr下标分别是01
第二次循环的时候,比较的desStr下标分别是12
……
当each1=6 的时候,循环内的第二个if语句就成了if desStr == subStr:,这不就越界了吗?desStr最大下标是6哎~
sunrise085 发表于 2020-4-28 14:06
没明白你说的“关系到语句长度的问题”是什么意思。
牛逼大佬,不好意思,我有点笨 sunrise085 发表于 2020-4-28 14:06
没明白你说的“关系到语句长度的问题”是什么意思。
def xunzhao(a):
b = temp.count(a)
return b
temp = input('请输入目标字符串:')
a = input('请输入子字符串(两个字符):')
print('子字符串在目标字符串中共出现'+ str(xunzhao(a))+ '次' )
你好大佬,我做出了一个简单一点的 牛逼牛逼 发表于 2020-4-28 17:29
def xunzhao(a):
b = temp.count(a)
return b
这个题目就是为了不用count函数,
你用count,那这个题目就没意义了
temp = input('请输入目标字符串:')
a = input('请输入子字符串(两个字符):')
print('子字符串在目标字符串中共出现',temp.count(a), '次' )
页:
[1]