• 扩展KMP的应用


    扩展KMP的应用:

     

    给出模板串S和串T,长度分别为Slen和Tlen,要求在线性时间内,对于每个S[i](0<=i<Slen),求出S[i..Slen-1]与T的

    最长公共前缀长度,记为extend[i](或者说,extend[i]为满足S[i..i+z-1]==T[0..z-1]的最大的z值)。

    扩展KMP可以用来解决很多字符串问题,如求一个字符串的最长回文子串和最长重复子串。


    https://www.61mon.com/index.php/archives/186/



    /*
     * 扩展KMP
     * next[i]:x[i...m-1]的最长公共前缀
     * extend[i]:y[i...n-1]与x[0...m-1]的最长公共前缀
     */
    
    void preEKMP(char x[], int m, int next[])
    {
        next[0] = m;
        int j = 0;
        while (j + 1 < m && x[j] == x[j + 1])
        {
            j++;
        }
        next[1] = j;
        int k = 1;
        for (int i = 2; i < m; i++)
        {
            int p = next[k] + k - 1;
            int L = next[i - k];
            if (i + L < p + 1)
            {
                next[i] = L;
            }
            else
            {
                j = std::max(0, p - i + 1);
                while (i + j < m && x[i + j] == x[j])
                {
                    j++;
                }
                next[i] = j;
                k = i;
            }
        }
        return ;
    }
    
    void EKMP(char x[], int m, char y[], int n, int next[], int extend[])
    {
        preEKMP(x, m, next);
        int j = 0;
        while (j < n && j < m && x[j] == y[j])
        {
            j++;
        }
        extend[0] = j;
        int k = 0;
        for (int i = 1; i < n; i++)
        {
            int p = extend[k] + k - 1;
            int L = next[i - k];
            if (i + L < p + 1)
            {
                extend[i] = L;
            }
            else
            {
                j = std::max(0, p - i + 1);
                while (i + j < n && j < m && y[i + j] == x[j])
                {
                    j++;
                }
                extend[i] = j;
                k = i;
            }
        }
        return ;
    }












  • 相关阅读:
    php 中的 Output Control 函数
    web安全知识
    php写一个web五子棋
    实现一个web服务器, 支持php
    字节序
    TinyHTTPd源码分析
    linux 管道通信
    linux网络编程
    微信公众号开发-静默授权实现消息推送(微服务方式)
    初学 Nginx
  • 原文地址:https://www.cnblogs.com/bryce1010/p/9387080.html
Copyright © 2020-2023  润新知