KMP的应用:Python和Go实现

kmp的作用

找到text中模式pattern的出现的pos
时间复杂度o(m + n)

Python实现

    def kmp(self, text: str, pattern: str) -> List[int]:m = len(pattern)pi = [0] * mc = 0for i in range(1, m):v = pattern[i]while c and pattern[c] != v:c = pi[c - 1]if pattern[c] == v:c += 1pi[i] = cres = []c = 0for i, v in enumerate(text):v = text[i]while c and pattern[c] != v:c = pi[c - 1]if pattern[c] == v:c += 1if c == len(pattern):res.append(i - m + 1)c = pi[c - 1]return res

Go实现

func kmp(text, pattern string) (pos []int) {m := len(pattern)pi := make([]int, m) // 前后缀匹配的长度, 不包括自身cnt := 0 // dpfor i := 1; i < m; i++ {v := pattern[i]// 若最大匹配不匹配,找次大匹配for cnt > 0 && pattern[cnt] != v {cnt = pi[cnt - 1]}// 如果匹配了长度加一if pattern[cnt] == v {cnt++}pi[i] = cnt // pi[i]表示到第i个前后缀匹配的最大长度}cnt = 0for i, v := range text {// 遍历textfor cnt > 0 && pattern[cnt] != byte(v) {cnt = pi[cnt - 1]}if pattern[cnt] == byte(v) {cnt++}// 若匹配长度就是m,成功if cnt == m {pos = append(pos, i - m + 1)cnt = pi[cnt - 1] // 回退一个,为后面的做准备}}return
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/626809.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

第二证券:利空因素影响成本端 豆粕期现价偏弱运行

上个买卖周&#xff0c;受利空要素影响&#xff0c;内盘豆粕期价刷新2021年12月14日以来收盘价新低。到上周五收盘&#xff0c;豆粕主力合约MO2405最低下探至3075元/吨&#xff0c;收报3078元/吨&#xff0c;周内累计跌幅近4%。业内人士以为&#xff0c;美国农业部超预期调高20…

Simon算法详解

0.0 Intro 相关的算法&#xff1a; Deutsh-Jozsa算法&#xff1a; 第一个量子算法对经典算法取得指数级加速的算法 美中不足在于只能确定函数是平衡的还是非平衡的&#xff0c;无法确定函数具体的内容&#xff0c;即无法直接解出函数 Bernstein-Vazirani算法&#xff…

Linux 内核指令动态替换

文章目录 前言ftraceStatic KeysStatic Calls 前言 Linux Kernel可以在运行时动态的&#xff08;即不需要重启&#xff09;替换内核指令&#xff0c;主要有以下三种方式。 ftrace linux 动态替换内核动态补丁&#xff08;kpatch&#xff09;及kpatch pushsection popsection…

C++面试合集问题之堆、栈

1.堆和栈的区别 分配方式&#xff1a; 堆&#xff1a;堆是由程序员手动分配和释放的一块内存区域。在堆上分配内存需要使用动态内存分配的方式&#xff0c;如malloc()、calloc()或new操作符&#xff0c;在不需要时需要手动释放内存&#xff0c;否则可能出现内存泄漏。堆上分配的…

恐龙岛如何正确的选择服务器

恐龙岛服务器的价格因配置和运营模式等因素而异。一般来说&#xff0c;BGP线路成本更高但更稳定&#xff0c;适用于全球分布广泛的玩家&#xff0c;适合高品质画面游戏。在选择合适的配置时&#xff0c;需要考虑运营模式、游戏玩家地区分布和游戏特性等因素。具体价格需要参考具…

外汇天眼:做交易要不要预测行情? 趋势交易最重要的三个核心概念!

对一个&#xff08;量化&#xff09;技术分析派来说&#xff0c;趋势是非常重要的&#xff0c;大家一般的想法都是通过趋势跟踪来挣钱的&#xff0c;无趋势时会有小的损耗&#xff0c;趋势来时用仓位来弥补损失并盈利&#xff0c;用盈亏比而不用胜率。 就趋势交易最重要的三个…

3D scanner with DLPC3478

https://www.bilibili.com/video/BV1vJ411J7ih?p3&vd_source109fb20ee1f39e5212cd7a443a0286c5 因数&#xff1a; 分别率波长pattern速度 DMD 与 DLPC匹配 3D scanner是结构光的概念走的 Internal pattern, 是DLPC内部提供图像给DMD External Pattern, 外部FPGA /MCU…

【Vue技巧】vue 阻止a链接跳转事件的两种方法

ChatGPT4.0国内站点&#xff0c;支持设计稿转代码&#xff1a;https://www.atalk-ai.com/ 在Vue中&#xff0c;如果你想阻止<a>链接的默认跳转事件&#xff0c;你可以使用click.prevent或者click配合.prevent修饰符。这样做可以阻止链接的默认行为&#xff0c;即不会跳转…

每日算法打卡:地宫取宝 day 16

文章目录 原题链接题目描述输入格式输出格式数据范围输入样例1&#xff1a;输出样例1&#xff1a;输入样例2&#xff1a;输出样例2&#xff1a; 题目分析示例代码 原题链接 1212. 地宫取宝 题目难度&#xff1a;中等 题目来源&#xff1a;第五届蓝桥杯省赛C A/B/C组,第五届蓝…

Spring基于AOP(面向切面编程)开发

概述 AOP为Aspect Oriented Programming的缩写&#xff0c;意为&#xff1a;面向切面编程&#xff0c;通过预编译方式和运行期间动态代理实现程序功能的统一维护的一种技术。AOP是OOP的延续&#xff0c;是软件开发中的一个热点&#xff0c;也是Spring框架中的一个重要内容&…

鸿蒙开发之手势Pan

Entry Component struct OfficialPanGesturePage {State message: string 默认只左右移动State offsetX: number 0State offsetY: number 0State positionX: number 0State positionY: number 0//默认pan的参数&#xff0c;1根手指&#xff0c;左右方向private panOption:…

Audio Precision SYS-2722音频分析仪

181/2461/8938产品概述&#xff1a; 2700系列专为需要最高性能的音频工程师而设计&#xff0c; 最低的失真和最大的灵活性。 2722的真正双域架构实现了以下方面的无与伦比的测量 模拟和数字信号:模拟发生器和分析仪性能超过 任何基于数字转换器的设计&#xff0c;而数字分析技…

三、基础篇 vue Class与Style绑定

操作元素的 class 列表和内联样式是数据绑定的一个常见需求。因为它们都是 attribute&#xff0c;所以我们可以用 v-bind 处理它们&#xff1a;只需要通过表达式计算出字符串结果即可。不过&#xff0c;字符串拼接麻烦且易错。因此&#xff0c;在将 v-bind 用于 class 和 style…

【面试突击】计算级网络面试实战(上)

&#x1f308;&#x1f308;&#x1f308;&#x1f308;&#x1f308;&#x1f308;&#x1f308;&#x1f308; 欢迎关注公众号&#xff08;通过文章导读关注&#xff1a;【11来了】&#xff09;&#xff0c;及时收到 AI 前沿项目工具及新技术 的推送 发送 资料 可领取 深入理…

2024年美赛美国大学生数学建模竞赛ABCDEF题思路资料汇总贴

下文包含&#xff1a;2024年美国大学生数学建模竞赛&#xff08;美赛&#xff09;A- F题思路解析、选题建议、代码可视化及如何准备数学建模竞赛&#xff08;2号发&#xff09; C君将会第一时间发布选题建议、所有题目的思路解析、相关代码、参考文献、参考论文等多项资料&…

关于跨域引用界面cookie不支持的处理

缘由&#xff1a;项目上与其他公司做对接&#xff0c;对方使用iframe引用我方项目&#xff0c;不使用nginx做代理&#xff0c;设置了老三样跨域请求头&#xff08;Access-Control-Allow&#xff09;&#xff0c;发现跨域cookie不识别&#xff0c;每次请求时返回头都携带新cooki…

docker filebeat 将日志多级目录和多维json数据日志同步到es

注 使用的时候先调试调试配置,调试成功在尝试写入es,如果es写入失败就是es账户.密码/白名单.和index未创建的问题,细节可以留言 setup.template.priority 模板优先级 调整这个可以配置一台机器多个filebeat 容器启动 多级目录日志和多维josn日志结构 filebeat.inputs:- typ…

如何使用ThinkPHP框架(thinkphp8.0)创建定时任务?

1、安装定时任务composer包 composer require easy-task/easy-task 2、创建命令行处理类文件 php think make:command Task task 会生成文件&#xff1a;app\command\Task.php 将Task.php文件内容修改如下&#xff1a; <?php declare (strict_types1);namespace app…

Jira REST API_检索多选自定义字段的可用选项

文章目录 背景解决方案背景 Jira Server/Data Center REST API不提供简单检索多选项自定义字段可用的所有选项的方法,只有 rest/api/2/customFieldOption/{id} API 获取指定的id的option值。 本文提供一种解决方法,,用于在通过 REST API 创建或编辑问题之前检索所有自定义字…

Linux:为什么要打包和压缩?

我们在Linux中已经学习了zip/unzip和tar两种方式来打包压缩文件&#xff0c;那么为什么要打包和压缩呢&#xff1f; 最直接的目的就是为了便于网络传输&#xff0c;防止传输过程中的数据丢失 举例实践 我们做个示例演示一下 我们创建一百个文件 我们将文件都放到dir里面来&…