poj 2774 lcp
来源:互联网 发布:什么是网络摄像头 编辑:程序博客网 时间:2024/04/29 05:05
写的太逗 多加了一个int
#include <cstdio>#include <cstring>#define maxn 200010char s[maxn];int n,m,sa[maxn],rank[maxn],height[maxn];int wa[maxn],wb[maxn],ws[maxn],wv[maxn];inline bool cmp(int *r,int a,int b,int l){ return (r[a] == r[b]) && (r[a+l] == r[b+l]);}inline void da(int n,int m){ int i,j,p,*x=wa,*y=wb,*t; memset(ws,0,sizeof(ws)); for (i=0;i<n;++i) ws[x[i]=s[i]]++; for (i=1;i<m;++i) ws[i]+=ws[i-1]; for (i=n-1;i>=0;--i) sa[--ws[x[i]]]=i; for (j=1,p=1;p<n;j<<=1,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<n;++i) wv[i]=x[y[i]]; for (i=0;i<m;++i) ws[i]=0; for (i=0;i<n;++i) ws[wv[i]]++; for (i=1;i<m;++i) ws[i]+=ws[i-1]; for (i=n-1;i>=0;--i) sa[--ws[wv[i]]]=y[i]; for (t=x,x=y,y=t,p=1,x[sa[0]]=0,i=1;i<n;++i) x[sa[i]]=cmp(y,sa[i-1],sa[i],j)?p-1:p++; }}inline void calcheight(){ int i,j,k=0; for (i=1;i<=n;++i) rank[sa[i]]=i; for (i=0;i<n;height[rank[i++]]=k) for (k?k--:0,j=sa[rank[i]-1];s[i+k]==s[j+k];k++);}int main(){ char s1[111111],s2[111111]; while(~scanf("%s%s",s1,s2)){ int a=(int)strlen(s1); int b=(int)strlen(s2); for(int i=0;i<a;++i)s[i]=s1[i]; s[a]=1; for(int i=0;i<b;++i)s[i+a+1]=s2[i]; n=a+b+1; //已定义 千万不要int了 da(n+1,255); calcheight(); int ans=0,tmp=0; for(int i=2;i<=n;++i) if(ans<height[i]) if((sa[i]<a&&sa[i-1]>a)||(sa[i]>a&&sa[i-1]<a)){ ans=height[i]; tmp=sa[i]; } printf("%d\n",ans); } return 0;}
0 0
- poj 2774 lcp
- POJ 2774 Long Long Message LCP后缀数组
- LCP
- LCP
- POJ 2001 Shortest Prefixes 【LCP(Trie)】
- LCP poj 2217 寻找最长公共子串
- POJ 1743 Musical Theme (二分后缀数组LCP)
- LCP概念
- LCP概念
- LCP Array
- POJ 3729 Facer’s string (后缀数组 两串后缀的LCP为K的对数)
- poj 1743 最长不重叠重复子串 后缀数组+lcp+二分
- 什么是LCP、PAP、IPCP
- 关于LCP协商
- 认识ppp和LCP
- (others)LCP
- (others)LCP报文
- 【GDKOI2013选拔】大LCP
- android模拟器如何切换输入法
- linux网络编程基础笔记
- iOS调用系统功能一览
- windows MFC时钟模拟
- 使用友盟SDK
- poj 2774 lcp
- 操作系统ucore实验_lab2_debug
- 缺训傥督凡窖植境盘釉酶赋黑诙谓
- U-BOOT环境变量实现
- C# 读取Excel的一些问题
- How Tomcat works之第十一章之Parent and Child
- 对ATDD的理解
- MFC制作简单的图片按钮
- 写一个自动备份的脚本