博客
关于我
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/

    你可能感兴趣的文章
    Openlayers实战:非4326,3857的投影
    查看>>
    Openlayers高级交互(1/20): 控制功能综合展示(版权、坐标显示、放缩、比例尺、测量等)
    查看>>
    Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
    查看>>
    Openlayers高级交互(11/20):显示带箭头的线段轨迹,箭头居中
    查看>>
    Openlayers高级交互(12/20):利用高德逆地理编码,点击位置,显示坐标和地址
    查看>>
    Openlayers高级交互(13/20):选择左右两部分的地图内容,横向卷帘
    查看>>
    Openlayers高级交互(14/20):汽车移动轨迹动画(开始、暂停、结束)
    查看>>
    Openlayers高级交互(15/20):显示海量多边形,10ms加载完成
    查看>>
    Openlayers高级交互(16/20):两个多边形的交集、差集、并集处理
    查看>>
    Openlayers高级交互(17/20):通过坐标显示多边形,计算出最大幅宽
    查看>>
    Openlayers高级交互(18/20):根据feature,将图形适配到最可视化窗口
    查看>>
    Openlayers高级交互(19/20): 地图上点击某处,列表中显示对应位置
    查看>>
    Openlayers高级交互(2/20):清除所有图层的有效方法
    查看>>
    Openlayers高级交互(20/20):超级数据聚合,页面不再混乱
    查看>>
    Openlayers高级交互(3/20):动态添加 layer 到 layerGroup,并动态删除
    查看>>
    Openlayers高级交互(4/20):手绘多边形,导出KML文件,可以自定义name和style
    查看>>
    Openlayers高级交互(5/20):右键点击,获取该点下多个图层的feature信息
    查看>>