比较简单的应用。

#include <stdio.h>
#include <string.h>
#define maxn 200002 int wa[maxn],wb[maxn],wv[maxn],ws[maxn];
int cmp(int *r,int a,int b,int l)
{return r[a]==r[b]&&r[a+l]==r[b+l];}
int max(int x,int y)
{return x>y?x:y;}
int min(int x,int y)
{return x<y?x:y;}
void da(int *r,int *sa,int n,int m)
{
int i,j,p,*x=wa,*y=wb,*t;
for(i=;i<m;i++) ws[i]=;
for(i=;i<n;i++) ws[x[i]=r[i]]++;
for(i=;i<m;i++) ws[i]+=ws[i-];
for(i=n-;i>=;i--) sa[--ws[x[i]]]=i;
for(j=,p=;p<n;j*=,m=p)
{
for(p=,i=n-j;i<n;i++) y[p++]=i;
for(i=;i<n;i++) if(sa[i]>=j) y[p++]=sa[i]-j;
for(i=;i<n;i++) wv[i]=x[y[i]];
for(i=;i<m;i++) ws[i]=;
for(i=;i<n;i++) ws[wv[i]]++;
for(i=;i<m;i++) ws[i]+=ws[i-];
for(i=n-;i>=;i--) sa[--ws[wv[i]]]=y[i];
for(t=x,x=y,y=t,p=,x[sa[]]=,i=;i<n;i++)
x[sa[i]]=cmp(y,sa[i-],sa[i],j)?p-:p++;
}
return;
}
int rank[maxn],height[maxn];
void calheight(int *r,int *sa,int n)
{
int i,j,k=;
for(i=;i<=n;i++) rank[sa[i]]=i;
for(i=;i<n;height[rank[i++]]=k)
for(k?k--:,j=sa[rank[i]-];r[i+k]==r[j+k];k++);
return;
}
int r[maxn],sa[maxn];
char s[maxn];
int main()
{
int i,j,len;
while(scanf("%s",s)!=EOF)
{
memset(r,,sizeof(r));
len=strlen(s);
s[len]=;
scanf("%s",s+len+);
int x=strlen(s);
for(i=;i<x;i++)r[i]=s[i];
da(r,sa,x+,);
calheight(r,sa,x);
int ans=;
for(i=;i<x;i++)
{
if(height[i]>ans)
{
if((sa[i-]+height[i]<len&&sa[i]>len)||(sa[i-]+height[i]>len&&sa[i]<len))
ans=height[i];
}
}
printf("%d\n",ans);
}
}

最新文章

  1. 放养的小爬虫--京东定向爬虫(AJAX获取价格数据)
  2. Swift 遍历数组元素
  3. Oracle的回收站和闪回查询机制(一)
  4. MVC理解
  5. 2013 南京邀请赛 A play the dice 求概率
  6. 开发一个微信小程序项目教程
  7. Cause: net.sf.cglib.beans.BulkBeanException; nested exception is com.ibatis.common.jdbc.exception.NestedSQLException:
  8. mysql 5.7.13 安装配置方法图文教程(linux) (转)
  9. CentOS6.8配置GO语言开发环境
  10. Stock Chase 拓扑
  11. mysql 查询优化 ~ select count 知多少
  12. Linux系统查看本机ip地址
  13. mod_conference ESL控制三(程序)
  14. Vue2.0+组件库总结
  15. CS模式,客户端页面加载
  16. QuickStart系列:docker部署之MongoDB
  17. byte[]-&gt;new String(byte[]) -&gt; getByte()引发的不一致问题
  18. 通过ReentrantLock简单了解下并发包中的锁
  19. bzoj 1539: [POI2005]Dwu-Double-row
  20. java 压缩与解压

热门文章

  1. javascript基础:dom
  2. BZOJ2982: combination Lucas模板
  3. 一个网页登陆界面写30多个测试Case——测试之道
  4. linux下文件操作之cp和mv
  5. global.fun.php
  6. bzoj 3033 太鼓达人——欧拉图搜索
  7. 移动端meta汇总
  8. CodeChef--EQUAKE
  9. php+js实现百度地图多点标注的方法
  10. jS生成二叉树,二叉树的遍历,查找以及插入