鱼C论坛

 找回密码
 立即注册
查看: 38|回复: 4

[已解决]if desStr[each1] == subStr[0]: if desStr[each1+1] == subStr[1]:这个是??

[复制链接]
发表于 昨天 21:20 | 显示全部楼层 |阅读模式

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

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

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():
    target = input("请输入目标字符串:")
    sub = input("请输入子字符串(两个字符)")
    count=target.count(sub)
    return count
print("子字符串在目标字符串中共出现的次数:",findstr())
请输入目标字符串:You cannot improve your past,but you can improve your future.Once time is wasted,life is wasted.
请输入子字符串(两个字符)ou
子字符串在目标字符串中共出现的次数: 4
可以满足题目要求。
老师的代码:
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)
最佳答案
昨天 21:20
首先,关于老师的代码中 if desStr == subStr: 这一行,确实存在错误。这里应该是检查目标字符串中从当前位置开始的两个字符是否等于子字符串,而不是直接比较整个字符串 desStrsubStr。这样比较的话,只有当整个目标字符串与子字符串完全相同时才会计数,无法统计子字符串出现的次数。这可能是代码编写时的笔误。

正确的逻辑应该是使用切片来检查每个长度为2的子串。老师的代码修正后如下:


  1. def findStr(desStr, subStr):
  2.     count = 0
  3.     length = len(desStr)
  4.     if subStr not in desStr:
  5.         print('在目标字符串中未找到字符串!')
  6.     else:
  7.         for i in range(length - 1):      
  8.             if desStr[i:i+2] == subStr:  # 检查从索引 i 开始的两个字符是否等于子字符串
  9.                 count += 1
  10.         print('子字符串在目标字符串中共出现 %d 次' % count)

  11. desStr = input('请输入目标字符串:')
  12. subStr = input('请输入子字符串(两个字符):')
  13. findStr(desStr, subStr)
复制代码


这样,循环遍历目标字符串的每个位置(除了最后一个字符,因为子字符串长度为2),并检查当前位置开始的两个字符是否与子字符串匹配,从而正确统计次数。

你的代码使用 target.count(sub) 方法,直接调用字符串的内置函数,非常简洁有效,完全满足题目要求。老师的代码则是为了演示如何手动遍历字符串来实现相同功能。两种方法都是可行的,但老师的原始代码有误,需要修正。

希望这个解释能帮助你理解!如果还有其他问题,请随时提出。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 昨天 21:20 | 显示全部楼层    本楼为最佳答案   
首先,关于老师的代码中 if desStr == subStr: 这一行,确实存在错误。这里应该是检查目标字符串中从当前位置开始的两个字符是否等于子字符串,而不是直接比较整个字符串 desStrsubStr。这样比较的话,只有当整个目标字符串与子字符串完全相同时才会计数,无法统计子字符串出现的次数。这可能是代码编写时的笔误。

正确的逻辑应该是使用切片来检查每个长度为2的子串。老师的代码修正后如下:


  1. def findStr(desStr, subStr):
  2.     count = 0
  3.     length = len(desStr)
  4.     if subStr not in desStr:
  5.         print('在目标字符串中未找到字符串!')
  6.     else:
  7.         for i in range(length - 1):      
  8.             if desStr[i:i+2] == subStr:  # 检查从索引 i 开始的两个字符是否等于子字符串
  9.                 count += 1
  10.         print('子字符串在目标字符串中共出现 %d 次' % count)

  11. desStr = input('请输入目标字符串:')
  12. subStr = input('请输入子字符串(两个字符):')
  13. findStr(desStr, subStr)
复制代码


这样,循环遍历目标字符串的每个位置(除了最后一个字符,因为子字符串长度为2),并检查当前位置开始的两个字符是否与子字符串匹配,从而正确统计次数。

你的代码使用 target.count(sub) 方法,直接调用字符串的内置函数,非常简洁有效,完全满足题目要求。老师的代码则是为了演示如何手动遍历字符串来实现相同功能。两种方法都是可行的,但老师的原始代码有误,需要修正。

希望这个解释能帮助你理解!如果还有其他问题,请随时提出。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 昨天 21:23 | 显示全部楼层
FishC 发表于 2026-4-12 21:20
首先,关于老师的代码中 if desStr == subStr: 这一行,确实存在错误。这里应该是检查目标字符串中从当前位 ...

哦哦哦,明白了,感谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 昨天 21:23 | 显示全部楼层
lukaka 发表于 2026-04-12 21:23
FishC 发表于 2026-4-12 21:20
首先,关于老师的代码 ...


不客气!很高兴能帮到你。

关于这个题目,你的实现方式(直接使用 count() 方法)非常棒,它是 Pythonic 的写法——简洁、高效且清晰。对于完成这个具体任务来说,你的代码是“标准答案”。

老师提供的代码(修正后)则展示了一种更“底层”的思维方式,它手动遍历并比较,这能帮助你更深入地理解字符串操作和循环的逻辑。在实际工作中,尤其是处理更复杂的匹配规则时,这种思路会非常有用。

这里再补充一个可能会遇到的问题,以及如何改进老师的代码使其更通用:

**如果子字符串长度固定为2,但你想统计“重叠”出现的情况(例如,在"aaa"中找"aa")怎么办?**

用 count() 方法默认是不统计重叠部分的,而老师的代码通过依次检查每一个位置,是可以统计重叠情况的。

另外,一个健壮的函数应该对输入做一些基本检查,我们可以稍微改进一下你的版本:


def findstr():
    target = input("请输入目标字符串:")
    sub = input("请输入子字符串:")
    # 可以检查子字符串长度是否为2
    if len(sub) != 2:
        print("请注意:本函数统计长度为2的子字符串,您输入的字符长度为 %d。" % len(sub))
        # 这里你可以选择直接返回,或者继续统计任意长度的子串
    count = target.count(sub)
    return count

result = findstr()
print("子字符串在目标字符串中共出现的次数:", result)

无论使用哪种方法,核心目标都是理解问题并找到有效的解决方案。你已经做到了!

继续加油,编程之路就是这样一步步积累起来的。如果还有其他疑问,随时可以提出来。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 1 小时前 | 显示全部楼层
学习了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-4-13 01:31

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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