QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#478743#801. 回文自动机liuhengxi0 0ms5716kbC++14873b2024-07-15 10:44:352024-07-15 10:44:36

Judging History

你现在查看的是最新测评结果

  • [2024-07-15 10:44:36]
  • 评测
  • 测评结果:0
  • 用时:0ms
  • 内存:5716kb
  • [2024-07-15 10:44:35]
  • 提交

answer

#include<cstdio>
#include<cstring>
#include<algorithm>
#define F(i,l,r) for(int i=(l),i##_end=(r);i<i##_end;++i)
using namespace std;
typedef long long ll;
constexpr int N=1e6+5;
struct node
{
	int tr[26],len,fail;
}a[N];
int n,ind,cur,occ[N];
char s[N];
int main()
{
	scanf("%s",s);
	n=(int)strlen(s);
	a[0].fail=1;
	a[1].fail=1;
	a[1].len=-1;
	ind=2;
	F(i,0,n)
	{
		if(a[cur].len==i)cur=a[cur].fail;
		while(s[i]!=s[i-a[cur].len-1])cur=a[cur].fail;
		int x=s[i]-'a';
		if(!a[cur].tr[x])
		{
			int u=ind++;
			a[u].len=a[cur].len+2;
			int v=a[cur].fail;
			while(v!=1&&!a[v].tr[x])v=a[v].fail;
			a[u].fail=a[v].tr[x];
			a[cur].tr[x]=u;
		}
		cur=a[cur].tr[x];
		++occ[cur];
	}
	for(int i=ind;--i>1;)occ[a[i].fail]+=occ[i];
	ll ans=0;
	F(i,2,ind)ans=max(ans,(ll)occ[i]*a[i].len*a[i].len);
	printf("%lld\n",ans);
	return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Subtask #1:

score: 0
Wrong Answer

Test #1:

score: 0
Wrong Answer
time: 0ms
memory: 5716kb

input:

bdgedcfadbabbfgeacdgbggaefddebabbfgeacdgbefaecfddffeddacbabfcgecedacbffeddacbabfebadggfafabcdfdeaabdeecgbcecegcgecedacbfgdagbgagafdegecadfebcdbgfacdecdegecadfebbcdfdeaabdbfgcbccfcaebcecfdfccagdafaeaacbggaefddebcbecdafageeaabcbdafadcbecdbcgcbdgedcfadbcaefbdfcbgfcdeceddaaffgcedfcdcgdcgbfdddfdadgagbbef...

output:

6132

result:

wrong answer expected '5594', found '6132'

Subtask #2:

score: 0
Skipped

Dependency #1:

0%