码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 蓝桥杯KMP总结


    本文给出了详解KMP原理的文章链接,以及蓝桥杯题单,并给出KMP模版题的题解。

    目录

    原理详解

    KMP题单

    KMP题解

    小蓝的字符串(模版题)

    题目描述

    输入描述

    输出描述

    输入输出样例

    求解方法一

    求解方法二


    原理详解

    KMP算法(研究总结,字符串) - SYCstudio - 博客园 (cnblogs.com)

    KMP题单

    1203:小明的字符串

    1628:最短循环节问题

    1071:串的前缀

    KMP题解

    小蓝的字符串(模版题)

    题目描述

    小明有两个字符串,分别为 S,T。

    请你求出 T 串的前缀在 S 串中出现的最长长度为多少。

    输入描述

    输入包含两行,每行包含一个字符串,分别表示 S,T。

    1≤∣S∣,∣T∣≤10^6,保证 S,T 只包含小写字母。

    输出描述

    输出共 11 行,包含一个整数,表示答案。

    输入输出样例

    示例 1

    输入

    1. aabba
    2. abb

    输出

    3
    

    示例 2

    输入

    1. aabba
    2. aba

    输出

    2

    求解方法一

    对每个T的前缀找S,暴力法(通过)。

    1. s=input()
    2. t=input()
    3. ans=0
    4. for i in range(len(t),0,-1):
    5. c=t[:i]
    6. if s.find(c)!=-1:
    7. ans=max(ans,i)
    8. print(ans)

    求解方法二

    KMP。

    1. N=100005
    2. ne=[0]*N
    3. def get_next(p):
    4. for i in range(1,len(p)):
    5. j=ne[i]
    6. while j and p[j]!=p[i]:
    7. j=ne[j]
    8. if p[j]==p[i]:ne[i+1]=j+1
    9. else:ne[i+1]=0
    10. def kmp(s,p):
    11. ans=0
    12. j=0
    13. get_next(p)
    14. for i in range(len(s)):
    15. while j and p[j]!=s[i]:
    16. j=ne[j]
    17. if p[j]==s[i]:
    18. j+=1
    19. ans=max(ans,j)
    20. if ans==len(p): return ans
    21. return ans
    22. s=input()
    23. t=input()
    24. print(kmp(s,t))

  • 相关阅读:
    SpringMVC-HttpMessageConverter(请求体/响应体)/文件下载与上传)
    【HDU No. 5057】序列操作 Argestes and Sequence
    【C语言刷LeetCode】2295. 替换数组中的元素(M)
    java毕业生设计二手车交易市场网站计算机源码+系统+mysql+调试部署+lw
    Java版分布式微服务云开发架构 Spring Cloud+Spring Boot+Mybatis 电子招标采购系统功能清单
    深度学习——卷积神经网络
    美团外卖搜索基于Elasticsearch的优化实践
    机器学习作业3____决策树(CART算法)
    016——DHT11驱动开发(基于I.MX6uLL)
    开发工具篇第七讲:阿里云日志查询与分析
  • 原文地址:https://blog.csdn.net/HP_C2H2/article/details/130905105
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号