码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 2024.6.14刷题记录-KMP记录


    目录

    一、831. KMP字符串 - AcWing题库

    1.普通版KMP

    2.代码简洁版KMP


    一、831. KMP字符串 - AcWing题库

    1.普通版KMP

    学习记录(http://t.csdnimg.cn/JxPv5)。解题代码如下:

    1. # KMP算法
    2. # 创建next数组
    3. def build_next(patt):
    4. i = 1
    5. n = len(patt)
    6. prefix_len = 0
    7. next = [0] * n
    8. while i < n:
    9. if patt[prefix_len] == patt[i]:
    10. # 匹配成功,继续匹配后面的
    11. prefix_len += 1
    12. next[i] = prefix_len
    13. i += 1
    14. else:
    15. # 匹配失败
    16. if prefix_len == 0:
    17. # 匹配下一个
    18. # next.append(0)
    19. i += 1
    20. else:
    21. # 跳转
    22. prefix_len = next[prefix_len - 1]
    23. return next
    24. patt_len = int(input())
    25. patt = input()
    26. string_len = int(input())
    27. string = input()
    28. next = build_next(patt)
    29. # kmp搜索
    30. i = 0
    31. j = 0
    32. ans = []
    33. while i < string_len:
    34. if string[i] == patt[j]:
    35. i += 1
    36. j += 1
    37. elif j > 0:
    38. # 跳转
    39. j = next[j - 1]
    40. else:
    41. # 一点不匹配
    42. i += 1
    43. if j == patt_len:
    44. # 找到子串
    45. ans.append(i - j)
    46. j = next[j - 1] # 注意这里是跳转
    47. for x in ans:
    48. print(x, end = ' ')

    2.代码简洁版KMP

    来自题解(AcWing 831. KMP字符串 - AcWing)。通过在字符串前面加一空格,减少j==0这一判断条件。

    1. # 代码更简洁版KMP
    2. if __name__ == '__main__':
    3. patt_len = int(input())
    4. patt = ' ' + input() # 使下标从1开始
    5. string_len = int(input())
    6. string = ' ' + input()
    7. next = [0] * (patt_len + 1)
    8. # next数组
    9. j = 0 # 匹配下标
    10. for i in range(2, patt_len + 1): # 类似主串下标
    11. while j and patt[i] != patt[j + 1]:
    12. # 跳转
    13. j = next[j]
    14. if patt[i] == patt[j + 1]:
    15. # 匹配成功,匹配下标加一
    16. j += 1
    17. next[i] = j
    18. # 字符串匹配
    19. j = 0
    20. for i in range(1, string_len + 1):
    21. while j and string[i] != patt[j + 1]:
    22. j = next[j]
    23. if string[i] == patt[j + 1]:
    24. j += 1
    25. if j == patt_len:
    26. print(i - j, end = ' ') # i+1-j-1 = i-j
    27. j = next[j]

    完

    感谢你看到这里!一起加油吧!

  • 相关阅读:
    VScode 关闭新建文件的语言选择提示后如何再开启
    现代数据架构-湖仓一体
    快速打开命令行方法集合
    阿里云Linux系统MySQL8忘记密码修改密码
    【SpringCloud】设置接口同时支持返回多种数据类型(json、xml)
    java8 function接口浅析(个人见解,如有错误,还请指正)
    【linux API 分析】register_chrdev
    深入浅出带你了解PHAR反序列化
    Qt5开发及实例V2.0-第十四章-Qt多国语言国际化
    HTTP代理SSL连接:保障网络安全的重要协议
  • 原文地址:https://blog.csdn.net/lshx4658/article/details/139673123
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号