标签:describe should error get ural message return scanf val
input | output |
---|---|
28 VOTEFORTHEGREATALBANIAFORYOU CHOOSETHEGREATALBANIANFUTURE |
THEGREATALBANIA |
题意:
给出两个字符串,求 最长公共子串
分析:
#include<cstdio> #include<cstring> #include<iostream> using namespace std; const int N=2e5+10; int n,len,id,ans,maxx,sa[N],tsa[N],rank[N],trank[N],h[N],c[N]; char s[N]; void DA(){ int p; memset(c,0,sizeof c);maxx=256; for(int i=1;i<=len;i++) c[rank[i]=s[i]]++; for(int i=2;i<=maxx;i++) c[i]+=c[i-1]; for(int i=len;i;i--) sa[c[rank[i]]--]=i; trank[sa[1]]=p=1; for(int i=2;i<=len;i++){ if(rank[sa[i]]!=rank[sa[i-1]]) p++; trank[sa[i]]=p; } for(int i=1;i<=len;i++) rank[i]=trank[i]; for(int k=1;p<len;k<<=1,maxx=p){ p=0; for(int i=len-k+1;i<=len;i++) tsa[++p]=i; for(int i=1;i<=len;i++) if(sa[i]>k) tsa[++p]=sa[i]-k; memset(c,0,sizeof c); for(int i=1;i<=len;i++) trank[i]=rank[tsa[i]]; for(int i=1;i<=len;i++) c[trank[i]]++; for(int i=2;i<=maxx;i++) c[i]+=c[i-1]; for(int i=len;i;i--) sa[c[trank[i]]--]=tsa[i]; trank[sa[1]]=p=1; for(int i=2;i<=len;i++){ if(rank[sa[i]]!=rank[sa[i-1]]||rank[sa[i]+k]!=rank[sa[i-1]+k]) p++; trank[sa[i]]=p; } for(int i=1;i<=len;i++) rank[i]=trank[i]; } for(int i=1,k=0;i<=len;i++){ int j=sa[rank[i]-1]; while(s[i+k]==s[j+k]) k++; h[rank[i]]=k;if(k>0) k--; } } int main(){ scanf("%*d"); scanf("%s",s+1);len=strlen(s+1);s[++len]=‘$‘;n=len+1; scanf("%s",s+n);len=strlen(s+1);//s[++len]=‘#‘; DA(); for(int i=2;i<=len;i++){ if((sa[i]>=n&&sa[i-1]<n)||(sa[i-1]>=n&&sa[i]<n)){ if(ans<h[i]){ ans=h[i]; id=sa[i]; } } } s[id+ans]=0; puts(s+id); return 0; }
标签:describe should error get ural message return scanf val
原文地址:http://www.cnblogs.com/shenben/p/6384171.html