Submission #47992

# Submission time Handle Problem Language Result Execution time Memory
47992 2018-05-09T10:33:57 Z Kmcode Palindromes (APIO14_palindrome) C++14
0 / 100
65 ms 35196 KB
#include "bits/stdc++.h"
using namespace std;

#define MAX 300015
char buf[MAX];
string s;

int len[MAX];
int linkk[MAX];
int nex[MAX][26];

int ord;
int cur;

int cnt[MAX];

void append(int idx) {
	char c = s[idx];
	while (!(idx-len[cur]-1>=0&&s[idx]==s[idx-len[cur]-1])) {
		cur = linkk[cur];
	}
	if (nex[cur][c - 'a'] == -1) {
		nex[cur][c - 'a'] = ord;
		ord++;
		len[nex[cur][c - 'a']] = len[cur] + 2;
		linkk[nex[cur][c - 'a']] = linkk[cur];
		cur = nex[cur][c - 'a'];
		if (len[cur] == 1) {
			linkk[cur] = 1;
		}
		else {
			while (nex[linkk[cur]][c - 'a'] == -1) {
				linkk[cur] = linkk[linkk[cur]];
				if (linkk[cur] == -1)exit(1);
			}
			linkk[cur] = nex[linkk[cur]][c - 'a'];
		}
	}
	else {
		cur = nex[cur][c - 'a'];
	}
	cnt[cur]++;
}

int main() {
	memset(nex, -1,sizeof(nex) );
	len[0] = -1;
	len[1] = 0;
	ord = 2;
	scanf("%s", buf);
	s = buf;
	linkk[1] = 0;
	linkk[0] = -1;
	for (int i = 0; i < s.size(); i++) {
		append(i);
	}
	long long int ans = 0;
	for (int i = ord - 1; i >= 2; i--) {
		cnt[linkk[i]] += cnt[i];
		ans = max(ans, (long long int)(len[i])*cnt[i]);
	}
	printf("%lld\n", ans);
	return 0;
}

Compilation message

palindrome.cpp: In function 'int main()':
palindrome.cpp:54:20: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for (int i = 0; i < s.size(); i++) {
                  ~~^~~~~~~~~~
palindrome.cpp:50:7: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%s", buf);
  ~~~~~^~~~~~~~~~~
# Verdict Execution time Memory Grader output
1 Correct 26 ms 30840 KB Output is correct
2 Correct 24 ms 30948 KB Output is correct
3 Correct 24 ms 31032 KB Output is correct
4 Correct 24 ms 31032 KB Output is correct
5 Correct 24 ms 31032 KB Output is correct
6 Correct 25 ms 31032 KB Output is correct
7 Correct 24 ms 31032 KB Output is correct
8 Correct 24 ms 31140 KB Output is correct
9 Correct 24 ms 31140 KB Output is correct
10 Incorrect 27 ms 31140 KB Output isn't correct
11 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 30 ms 31140 KB Output is correct
2 Correct 24 ms 31140 KB Output is correct
3 Correct 24 ms 31140 KB Output is correct
4 Correct 24 ms 31352 KB Output is correct
5 Correct 24 ms 31352 KB Output is correct
6 Correct 24 ms 31352 KB Output is correct
7 Correct 24 ms 31352 KB Output is correct
8 Correct 24 ms 31352 KB Output is correct
9 Correct 24 ms 31352 KB Output is correct
10 Correct 24 ms 31352 KB Output is correct
11 Correct 24 ms 31352 KB Output is correct
12 Incorrect 29 ms 31352 KB Output isn't correct
# Verdict Execution time Memory Grader output
1 Correct 25 ms 31352 KB Output is correct
2 Correct 26 ms 31352 KB Output is correct
3 Correct 24 ms 31352 KB Output is correct
4 Correct 24 ms 31352 KB Output is correct
5 Correct 24 ms 31356 KB Output is correct
6 Correct 24 ms 31356 KB Output is correct
7 Correct 25 ms 31356 KB Output is correct
8 Correct 26 ms 31356 KB Output is correct
9 Correct 25 ms 31356 KB Output is correct
10 Incorrect 25 ms 31356 KB Output isn't correct
# Verdict Execution time Memory Grader output
1 Correct 27 ms 32508 KB Output is correct
2 Correct 29 ms 32508 KB Output is correct
3 Correct 28 ms 32636 KB Output is correct
4 Correct 28 ms 32636 KB Output is correct
5 Correct 28 ms 32636 KB Output is correct
6 Correct 29 ms 32636 KB Output is correct
7 Correct 35 ms 32636 KB Output is correct
8 Correct 26 ms 32636 KB Output is correct
9 Correct 33 ms 32636 KB Output is correct
10 Incorrect 65 ms 32636 KB Output isn't correct
# Verdict Execution time Memory Grader output
1 Correct 58 ms 35196 KB Output is correct
2 Correct 35 ms 35196 KB Output is correct
3 Correct 35 ms 35196 KB Output is correct
4 Correct 38 ms 35196 KB Output is correct
5 Correct 38 ms 35196 KB Output is correct
6 Correct 36 ms 35196 KB Output is correct
7 Correct 38 ms 35196 KB Output is correct
8 Correct 30 ms 35196 KB Output is correct
9 Correct 30 ms 35196 KB Output is correct
10 Incorrect 35 ms 35196 KB Output isn't correct
11 Halted 0 ms 0 KB -