摘要: 题意: 给你两串字符,要你找出在这两串字符中都出现过的最长子串 解析: 先用个分隔符将两个字符串连接起来,再用后缀数组求出height数组的值,找出一个height值最大并且i与i-1的sa值分别在两串字符中就好了 阅读全文
posted @ 2018-08-17 21:39 WTSRUVF 阅读(319) 评论(0) 推荐(0) 编辑
摘要: 后缀数组专题的 emm。。 就next 循环节。。/ 有后缀数组也可以做 从小到大枚举长度i,如果长度i的子串刚好是重复了len/i次,应该满足len % i == 0和rank[0] - rank[i] == 1(整个串的等级比 i位置开始的后缀的等级大1 (i位置开始的后缀即为比总串低一个等级的 阅读全文
posted @ 2018-08-17 18:44 WTSRUVF 阅读(140) 评论(0) 推荐(0) 编辑
摘要: 求不重复的子串个数 用所有的减去height就好了 推出来的。。。 阅读全文
posted @ 2018-08-17 18:19 WTSRUVF 阅读(176) 评论(0) 推荐(0) 编辑
摘要: 题意: 求可重叠的最长重复子串,但有一个限制条件。。要至少重复k次 解析: 二分枚举k,对于连续的height 如果height[i] >= k 说明它们至少有k个元素是重复的,所以判断一下就好了 数据很水 输入数据可能为0,所以s[i]++ s[n++] = 0; 要后缀数组要保证末尾加的字符比前 阅读全文
posted @ 2018-08-17 17:21 WTSRUVF 阅读(181) 评论(0) 推荐(0) 编辑
摘要: 求不可重叠最长重复子串 对于height[i]定义为sa[i]和 sa[i-1]的最长公共前缀 这个最长公共前缀的值肯定是最大的 证明: 设rank[j] < rank[k], 则不难证明后缀j和k的LCP的长度等于height[rank[j]+1], height[rank[j]+2],```, 阅读全文
posted @ 2018-08-17 11:19 WTSRUVF 阅读(151) 评论(0) 推荐(0) 编辑