查找字符串
编写一个函数 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 == subStr:
if desStr == subStr:
count += 1
print('子字符串在目标字符串中共出现 %d 次' % count)
desStr = input('请输入目标字符串:')
subStr = input('请输入子字符串(两个字符):')
findStr(desStr, subStr)
我的代码:
def findstr():
print('请输入目标字符串:', end = '')
str1 = input()
print('请输入子字符串(两个字符)', end = '')
str2 = input()
num = str1.count(str2)
print('子字符串在目标字符串中共出现', num, '次')
请帮忙看看我这样写有什么问题?
def findstr():
print('请输入目标字符串:', end='')
str1 = input()
print('请输入子字符串(两个字符):', end='')
str2 = input()
# 检查子串长度是否为2
if len(str2) != 2:
print('错误:子字符串必须为两个字符')
return
count = 0
# 遍历所有可能的起始位置(包括重叠情况)
for i in range(len(str1)-1):
if str1 == str2:
count += 1
if count == 0:
print('在目标字符串中未找到子字符串!')
else:
print('子字符串在目标字符串中共出现', count, '次')
你的代码存在两个主要问题:
[*] 未处理子字符串重叠的情况:str.count() 方法统计的是非重叠出现次数。例如在 "imim" 中找 "im",正确应该统计2次,而用count方法会正确;但在 "iiiim" 中找 "ii",正确应该统计3次(位置0-1、1-2、2-3),用count方法只会统计2次
[*] 未校验子字符串长度:题目明确要求子字符串长度为2,但你的代码未做校验,如果用户输入1个或3个字符会导致统计错误
改进说明:
1. 通过循环逐字符检查 str1
2. 遍历范围是 len(str1)-1 确保最后能取到两个字符
3. 增加子字符串长度校验
以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。 除了代码可以再简化一下,没有问题。
简化:将 print() 和它后面的 input() 合并
def findstr():
str1 = input('请输入目标字符串:')
str2 = input('请输入子字符串(两个字符)')
num = str1.count(str2)
print('子字符串在目标字符串中共出现', num, '次') 本帖最后由 jackz007 于 2025-5-8 22:44 编辑
函数具有工具属性,应该适合通用,所以,应该在全缄默的状态下工作,也就是说,函数必须尽量避免键盘输入和屏幕输出。
参考代码:
def findstr(desStr , subStr) :
c , i = 0 , 0
if len(desStr) >= len(subStr) and len(subStr) == 2 :
while i < len(desStr) - 1 :
if desStr == subStr :
c , i = c + 1 , i + 1
i += 1
return c
str1 = input('请输入目标字符串:')
str2 = input('请输入子字符串(两个字符):')
print('子字符串在目标字符串中共出现' , findstr(str1 , str2) , '次')
页:
[1]