QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#44841 | #801. 回文自动机 | He_Ren# | 0 | 1ms | 4184kb | C++14 | 1.2kb | 2022-08-22 08:54:45 | 2022-08-22 08:54:47 |
Judging History
answer
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair<int,int> pii;
const int MAXN = 1e6 + 10;
namespace PAM
{
int son[MAXN][26], len[MAXN], fail[MAXN], pcnt, s[MAXN], n;
int insert(int u,int c)
{
while(s[n - len[u] - 1] != s[n]) u = fail[u];
if(son[u][c]) return son[u][c];
int v = ++pcnt; len[v] = len[u] + 2;
int w = fail[u];
while(s[n - len[w] - 1] != s[n]) w = fail[w];
fail[v] = w;
son[u][c] = v;
return v;
}
int f[MAXN], bak[MAXN], seq[MAXN];
ll build(char *_s,int _n)
{
pcnt = 1; len[0] = 0; len[1] = -1; fail[0] = 1; n = 0; s[0] = -1;
int lst = 0;
for(int i=1; i<=_n; ++i)
{
s[++n] = _s[i] - 'a';
lst = insert(lst, s[n]);
++f[lst];
}
for(int i=2; i<=pcnt; ++i)
++bak[len[i]];
for(int i=1; i<=n; ++i)
bak[i] += bak[i-1];
for(int i=pcnt; i>=2; --i)
seq[bak[len[i]]--] = i;
ll ans = 0;
for(int i=pcnt-1; i>=1; --i)
{
int u = seq[i];
f[fail[u]] += f[u];
ans = max(ans, (ll)f[u] * len[u] * len[u]);
}
return ans;
}
}
char s[MAXN];
int main(void)
{
scanf("%s",s+1);
int n = strlen(s+1);
ll ans = PAM :: build(s, n);
printf("%lld\n",ans);
return 0;
}
詳細信息
Subtask #1:
score: 0
Wrong Answer
Test #1:
score: 0
Wrong Answer
time: 1ms
memory: 4184kb
input:
bdgedcfadbabbfgeacdgbggaefddebabbfgeacdgbefaecfddffeddacbabfcgecedacbffeddacbabfebadggfafabcdfdeaabdeecgbcecegcgecedacbfgdagbgagafdegecadfebcdbgfacdecdegecadfebbcdfdeaabdbfgcbccfcaebcecfdfccagdafaeaacbggaefddebcbecdafageeaabcbdafadcbecdbcgcbdgedcfadbcaefbdfcbgfcdeceddaaffgcedfcdcgdcgbfdddfdadgagbbef...
output:
4772
result:
wrong answer expected '5594', found '4772'
Subtask #2:
score: 0
Skipped
Dependency #1:
0%