博客
关于我
KMP 总结
阅读量:728 次
发布时间:2019-03-21

本文共 954 字,大约阅读时间需要 3 分钟。

KMP字符串匹配算法是High_broadcast的核心,next数组是其关键结构。本文将详细解析如何生成KMP算法中的next数组。

KMP算法介绍

KMP(Knuth-Morris-Pratt)算法是一种高效的字符串匹配算法,通过预处理字符串时间在线性预处理后,能够在线性时间内完成子串搜索任务。其核心思想在于预先生成next数组,每个数组元素表示在当前位置匹配失败时,应该退回的位置,从而避免重复匹配,提升搜索效率。

next数组生成逻辑

生成next数组的逻辑可分为以下几个步骤:

  • 初始化:首先需要一个存储长度等于字符串长度的数组next,用于记录各个位置的最大退回值。

  • 遍历字符串:从第二个字符开始逐个遍历字符串。

    • 如果当前字符与前j个字符中的某个字符相同,则j递增。
    • 如果不相同,则将j移动到前一个匹配点的下一个位置,即j = next[j-1],继续比较。
  • 记录结果:当匹配成功时,将当前j的值记录在next数组中。

  • 具体实现代码

    以下是KMP算法中next数组生成的具体实现代码:

    private int[] nextArray(String str) {    int[] next = new int[str.length()];    int j = 0;    for (int i = 1; i < str.length(); i++) {        while (j > 0 && str.charAt(i) != str.charAt(j)) {            j = next[j - 1];        }        if (str.charAt(i) == str.charAt(j)) {            j++;        }        next[i] = j;    }    return next;}

    通过上述代码,我们可以清晰地看到KMP算法如何生成next数组。这个数组是实现算法高效性的关键,它记录了每个位置可能的最大退回值。

    总结

    KMP算法通过预先生成next数组,显著提升了字符串匹配的效率。理解next数组的生成逻辑是掌握KMP算法的关键。通过以上步骤,我们可以清晰地看到如何根据已匹配的前缀来确定下一步的匹配位置。

    转载地址:http://lbvgz.baihongyu.com/

    你可能感兴趣的文章
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_插入时如果目标表中已存在该数据则自动改为更新数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0058
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0_Postgresql和Mysql同时指定库_指定多表_全量同步到Mysql数据库以及Hbase数据库中---大数据之Nifi工作笔记0060
    查看>>
    NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
    查看>>
    NIFI1.21.0最新版本安装_配置使用HTTP登录_默认是用HTTPS登录的_Https登录需要输入用户名密码_HTTP不需要---大数据之Nifi工作笔记0051
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增加修改实时同步_使用JsonPath及自定义Python脚本_03---大数据之Nifi工作笔记0055
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_插入修改删除增量数据实时同步_通过分页解决变更记录过大问题_01----大数据之Nifi工作笔记0053
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
    查看>>
    NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现update数据实时同步_实际操作05---大数据之Nifi工作笔记0044
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>