标签:could nbsp sso ash tle sms str 等级 main
Description
Input
Output
Sample Input
yeshowmuchiloveyoumydearmotherreallyicannotbelieveit yeaphowmuchiloveyoumydearmother
Sample Output
27
题意:
给你两个字符串长度不超过1e5
问你最长公共子串的长度
题解:
百度搜一发后缀数组,资料一大把,看完之后呢,然后弱弱抄板子
#include <iostream> #include <cstdio> #include <cmath> #include <cstring> #include <algorithm> using namespace std; #pragma comment(linker, "/STACK:102400000,102400000") #define ls i<<1 #define rs ls | 1 #define mid ((ll+rr)>>1) #define pii pair<int,int> #define MP make_pair typedef long long LL; const long long INF = 1e18+1LL; const double Pi = acos(-1.0); const int N = 2e5+10, M = 2e5+20, mod = 1e9+7, inf = 2e9; ///heght[i] 表示 Suffix(sa[i-1])和Suffix(sa[i]) 的最长公共前缀: ///rank[i] 表示 开头为i的后缀的等级: ///sa[i] 表示 排名为i的后缀 的开头位置: int *rank,r[N],sa[N],height[N],wa[N],wb[N],wm[N]; bool cmp(int *r,int a,int b,int l) { return r[a] == r[b] && r[a+l] == r[b+l]; } void SA(int *r,int *sa,int n,int m) { int *x=wa,*y=wb,*t; for(int i=0;i<m;++i)wm[i]=0; for(int i=0;i<n;++i)wm[x[i]=r[i]]++; for(int i=1;i<m;++i)wm[i]+=wm[i-1]; for(int i=n-1;i>=0;--i)sa[--wm[x[i]]]=i; for(int i=0,j=1,p=0;p<n;j=j*2,m=p){ for(p=0,i=n-j;i<n;++i)y[p++]=i; for(i=0;i<n;++i)if(sa[i]>=j)y[p++]=sa[i]-j; for(i=0;i<m;++i)wm[i]=0; for(i=0;i<n;++i)wm[x[y[i]]]++; for(i=1;i<m;++i)wm[i]+=wm[i-1]; for(i=n-1;i>=0;--i)sa[--wm[x[y[i]]]]=y[i]; for(t=x,x=y,y=t,i=p=1,x[sa[0]]=0;i<n;++i) { x[sa[i]]=cmp(y,sa[i],sa[i-1],j)?p-1:p++; } } rank=x; } void Height(int *r,int *sa,int n) { for(int i=0,j=0,k=0;i<n;height[rank[i++]]=k) for(k?--k:0,j=sa[rank[i]-1];r[i+k] == r[j+k];++k); } char s[N*2]; int main() { while(~scanf("%s",s)) { int n=strlen(s); int flag = n; for(int i = 0; i < n; ++i) r[i]=s[i]; r[n] = ‘#‘; scanf("%s",s); int len = strlen(s); for(int i=0;i<len;++i) r[n+1+i]=s[i]; n += len; r[n+1] = 0; SA(r,sa,n+2,256); Height(r,sa,n+1); int ans = 0; for(int i = 1; i <= n; ++i) { int mi = min(sa[i],sa[i-1]); int mx = max(sa[i],sa[i-1]); if(mi < flag && mx > flag) ans = max(ans,height[i]); } printf("%d\n",ans); } return 0; }
POJ 2774 Long Long Message 后缀数组
标签:could nbsp sso ash tle sms str 等级 main
原文地址:http://www.cnblogs.com/zxhl/p/5990039.html