⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pku 2774 后缀数组.txt

📁 NUAA ACM OJ源码
💻 TXT
字号:
#include <iostream>
using namespace std;

//PKU 2774 后缀数组

const int maxn = 100000*2;
int  c[maxn], h[maxn], smem[3][maxn];
int *SA, *nSA, *Rank, *nRank;
int MAX, n, K;
char num[maxn];
int len2, len1;
void suffix_array()
{
	int i, j, k;
	SA=smem[0], nSA=smem[1], Rank=smem[2];
	memset( c, 0, sizeof(c) );
	for( i = 0; i < n; i++ ) c[num[i]+1]++;
	for( i = 1; i < MAX; i++ ) c[i]+=c[i-1];
	for( i = 0; i < n; i++ )  SA[--c[num[i]+1]]=i;
	for( Rank[SA[0]] = 0,i = 1; i < n; i++ )
	{
		Rank[SA[i]] = Rank[SA[i-1]];
		if( num[SA[i-1]] != num[SA[i]] )	Rank[SA[i]]++;
	}	
    // SA[i] = j, Rank[j] = i
	for( k = 1; k < n && Rank[ SA[n-1] ] < n-1; k *= 2 )
	{
		for( i = 0; i < n;i++ )c[Rank[SA[i]]] = i+1;
		for( i = n-1; i >= 0;i-- )
		{
			if( SA[i] >= k )
			{	nSA[ --c[Rank[SA[i]-k]] ] = SA[i]-k;}
        }
		for( i = n-k; i < n; i++ )
		{	nSA[ --c[Rank[i]] ] = i;}
		nRank = SA, SA = nSA;
		for( nRank[SA[0]] = 0, i = 1; i < n; i++ )
		{
			nRank[SA[i]] = nRank[SA[i-1]];
			if( Rank[SA[i]] != Rank[SA[i-1]] || Rank[SA[i]+k] != Rank[SA[i-1]+k] )
			{	nRank[SA[i]]++;}
		}
		nSA = Rank;  Rank = nRank;
	}
}
int get_lcp()
{
	int i, j, k, ret, t;
	for( i = 0, k = 0; i < n; i++ )
	{
		if( Rank[i] == n-1 )
			h[Rank[i]] = k = 0;
		else
		{
			if( k  > 0 )
			{	k--; }
			j = SA[Rank[i]+1];
			while( num[i+k] == num[j+k] )
			{	k++; }
			h[Rank[i]] = k;
		}
	}
	ret = 0;
	for( i = 0; i < n-1; i++ )
	{  //h[]为高度数组, h[i]=lcp(SA[i],SA[i+1]);
	   //                  SA[i]和SA[i+1]必须满足一个在前另一个在后 
		if( ret < h[i] && (SA[i]<len1) != (SA[i+1]<len1) )////////////
		{	ret = h[i]; }
    }
	return ret;
}
int main()
{
	gets( num );
	len1=strlen( num );
	gets( num + len1 );
	len2=strlen( num + len1 );
	n=len1 + len2;
	num[n++] = 1;////////////这个是必需的  
	MAX = 200;
	suffix_array();
	printf( "%d\n",get_lcp() );
	return 0;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -