ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

字符串算法_Z 函数_扩展 KMP

2022-04-29 22:00:39  阅读:165  来源: 互联网

标签:子串 定义 int 算法 vector KMP 字符串


定义:z[i] 定义为 s[i~n-1] 与 s 的最长公共前缀长度

https://www.cnblogs.com/kingbuffalo/p/16186634.html 所讲
设 z[0~i] 已算好
现在求 z[i+1] ,那么,如果z[0~i]有一点x值能覆盖 i+1 ,
则证明 z[i+1] 的值 与 s[i-x] == s[i+1] ,如果范围合理,则:z[i+1] = z[i-x];

应用
  1. 匹配所有子串
  2. 本质不同子串数
  3. 字符串整周期
核心算法
vector<int> z_function(string s) {
  int n = (int)s.length();
  vector<int> z(n);
  for (int i = 1, l = 0, r = 0; i < n; ++i) {
    if (i <= r && z[i - l] < r - i + 1) {
      z[i] = z[i - l];
    } else {
      z[i] = max(0, r - i + 1);
      while (i + z[i] < n && s[z[i]] == s[i + z[i]]) ++z[i];
    }
    if (i + z[i] - 1 > r) l = i, r = i + z[i] - 1;
  }
  return z;
}

习题: poj2752 http://poj.org/problem?id=2752

标签:子串,定义,int,算法,vector,KMP,字符串
来源: https://www.cnblogs.com/kingbuffalo/p/16196105.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有