# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
21911 | Yousef_Salama | 회문 (APIO14_palindrome) | C++14 | 89 ms | 67808 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
const int MAXN = 300005;
char s[MAXN];
int N;
int suflink[MAXN], g[MAXN][26], length[MAXN], flag[MAXN], M, p;
vector <int> G[MAXN];
void init(){
memset(suflink, -1, sizeof suflink);
memset(g, -1, sizeof g);
length[0] = -1;
length[1] = 0;
suflink[1] = 0;
G[0].push_back(1);
M = 2;
p = 1;
}
void extend(int i){
while((i - length[p] - 1 < 0) || (s[i] != s[i - length[p] - 1]))
p = suflink[p];
if(g[p][s[i] - 'a'] != -1){
flag[g[p][s[i] - 'a']]++;
p = g[p][s[i] - 'a'];
}else{
int q = M++;
g[p][s[i] - 'a'] = q;
length[q] = length[p] + 2;
while(true){
if(p == 0){
suflink[q] = 1;
break;
}
p = suflink[p];
if(g[p][s[i] - 'a'] != -1){
suflink[q] = g[p][s[i] - 'a'];
break;
}
}
G[suflink[q]].push_back(q);
flag[q]++;
p = q;
}
}
int occ[MAXN];
long long solve(int i){
occ[i] = flag[i];
long long r = 0;
for(int j : G[i]){
r = max(r, solve(j));
occ[i] += occ[j];
}
r = max(r, (long long)occ[i] * length[i]);
return r;
}
int main(){
scanf("%s", s);
N = strlen(s);
init();
for(int i = 0; i < N; i++)
extend(i);
printf("%lld\n", solve(0));
return 0;
}
컴파일 시 표준 에러 (stderr) 메시지
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |