2013年8月23日

spoj 694. Distinct Substrings 后缀数组求不同子串的个数

摘要: 题目链接:http://www.spoj.com/problems/DISUBSTR/思路:每个子串一定是某个后缀的前缀,那么原问题等价于求所有后缀之间的不相同的前缀的个数。如果所有的后缀按照suffix(sa[1]),suffix(sa[2]),suffix(sa[3]),……suffix(sa[n])的顺序计算,不难发现,对于每一次新加进来的后缀suffix(sa[k]),它将产生n-sa[k]+1个新的前缀。但是其中有height[k]个是和前面的字符串的前缀是相同的。所以suffix(sa[k])将“贡献”出n-sa[k]+1-height[k]个不同的子串。累加后便是原问题的答案。这 阅读全文

posted @ 2013-08-23 22:14 GyyZyp 阅读(200) 评论(0) 推荐(0) 编辑

ural 1297. Palindrome

摘要: 题目链接:http://acm.timus.ru/problem.aspx?space=1&num=1297求最长回文子串典型的后缀数组的入门题目,但是可以用更简单的方法解决,毕竟数据量比较小啊转载:题目大意:给出一个字符串,求它的连续最长回文子串。分析:这题数据规模不大(n 2 #include 3 #include 4 using namespace std; 5 const int maxn=2010; 6 int n,w[maxn],wa[maxn],wb[maxn],wv[maxn]; 7 int a[maxn],sa[maxn],rank[maxn],height[maxn 阅读全文

posted @ 2013-08-23 19:38 GyyZyp 阅读(192) 评论(0) 推荐(0) 编辑

poj3261 Milk Patterns 后缀数组求可重叠的k次最长重复子串

摘要: 题目链接:http://poj.org/problem?id=3261思路:后缀数组的很好的一道入门题目先利用模板求出sa数组和height数组然后二分答案(即对于可能出现的重复长度进行二分) ,二分的时候,对 height进行分组,看是否存在一组height值使得其重复的次数大于等于k代码如下: 1 #include 2 #include 3 #include 4 #include 5 using namespace std; 6 #define maxn 20010 7 int wa[maxn],wb[maxn],wv[maxn],wq[maxn]; 8 int rank[maxn],sa 阅读全文

posted @ 2013-08-23 15:56 GyyZyp 阅读(163) 评论(0) 推荐(0) 编辑

poj1743 Musical Theme 后缀数组的应用(求最长不重叠重复子串)

摘要: 题目链接:http://poj.org/problem?id=1743题目理解起来比较有困难,其实就是求最长有N(1 2 #include 3 #include 4 #include 5 using namespace std; 6 #define maxn 20010 7 8 int wa[maxn],wb[maxn],wv[maxn],wq[maxn]; 9 int height[maxn];10 int s[maxn];11 int rank[maxn];12 int sa[maxn];13 bool cmp(int *r,int a,int b,int l)14 {return r.. 阅读全文

posted @ 2013-08-23 11:19 GyyZyp 阅读(162) 评论(0) 推荐(0) 编辑

后缀数组模板

摘要: /*后缀数组模板*/#include#include#include#include#define maxn 1010using namespace std;int wa[maxn],wb[maxn],wv[maxn],wq[maxn];int rank[maxn],sa[maxn];int r[maxn];int height[maxn];int cmp(int *r,int a,int b,int l){return r[a]==r[b]&&r[a+l]==r[b+l];}void da(int *r,int *sa,int n,int m)//n为字符串长度 m为字符串取 阅读全文

posted @ 2013-08-23 11:11 GyyZyp 阅读(125) 评论(0) 推荐(0) 编辑

导航