QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#595121 | #9417. Palindromic Polygon | ucup-team5008# | WA | 0ms | 3932kb | C++23 | 3.7kb | 2024-09-28 12:38:12 | 2024-09-28 12:38:30 |
Judging History
answer
#include <cstdio>
#include <cstring>
#include <vector>
#include <cassert>
#include <algorithm>
const int N = 505;
int tt, n, col_cnt, a[N], col[N];
long long dp[N][N];
std::vector<int> pos[N];
bool vis[N];
struct point {
int x, y;
point(int x = 0, int y = 0) {
this->x = x;
this->y = y;
}
} p[N];
point operator-(point a, point b) {
return point(a.x - b.x, a.y - b.y);
}
long long cross(point a, point b) {
return (long long)a.x * b.y - a.y * b.x;
}
long long area(point a, point b, point c, point d) {
return cross(a, b) + cross(b, c) + cross(c, d) + cross(d, a);
//return cross(a - b, c - b) + cross(b - c, d - c) + cross(c - d, a - d) + cross(d - a, b - a);
}
int dist(int l, int r) {
if (l < r) return r - l;
return r + n - l;
}
void update(int l, int r, int i, int j) {
assert(a[i] == a[j]);
dp[l][r] = std::max(dp[l][r], area(p[l], p[i], p[j], p[r]) + dp[i][j]);
}
int main() {
scanf("%d", &tt);
while (tt--) {
scanf("%d", &n);
for (int i = 0; i < n; ++i) {
scanf("%d", a + i);
col[i] = a[i];
pos[i].clear();
}
std::sort(col, col + n);
col_cnt = std::unique(col, col + n) - col;
for (int i = 0; i < n; ++i) {
a[i] = std::lower_bound(col, col + col_cnt, a[i]) - col;
//printf("%d ", a[i]);
pos[a[i]].push_back(i);
}
//printf("\n");
for (int i = 0; i < n; ++i) {
scanf("%d%d", &p[i].x, &p[i].y);
dp[i][i] = 0;
}
long long ans = 0;
for (int len = 1; len < n; ++len) {
int r = len;
for (int l = 0; l < n; ++l, ++r) {
if (r == n) r = 0;
if (a[l] != a[r]) continue;
dp[l][r] = 0;
for (int i = l + 1;; ++i) {
if (i == n) i = 0;
if (i == r) break;
dp[l][r] = std::max(dp[l][r], cross(p[r] - p[i], p[l] - p[i]));
}
/*
for (int i = l + 1;; ++i) {
if (i == n) i = 0;
if (i == r) break;
for (int j = i + 1;; ++j) {
if (j == n) j = 0;
if (j == r) break;
if (a[i] == a[j]) dp[l][r] = std::max(dp[l][r], area(p[l], p[i], p[j], p[r]) + dp[i][j]);
}
}
*/
int cur_col = -1, cur_pos = -1, cur_dist = n;
memset(vis, 0, col_cnt);
for (int i = l + 1;; ++i) {
if (i == n) i = 0;
if (i == r) break;
if (vis[a[i]]) {
if (cur_col == a[i]) update(l, r, i, cur_pos);
} else {
vis[a[i]] = true;
for (int j = 0; j < (int)pos[a[i]].size(); ++j) {
int p = pos[a[i]][j];
if (p != r && p != l && p != i && dist(i, r) == dist(i, p) + dist(p, r)) {
update(l, r, i, p);
if (cur_dist > dist(p, r)) {
cur_col = a[i];
cur_pos = p;
cur_dist = dist(p, r);
}
}
}
}
}
ans = std::max(ans, dp[l][r]);
}
}
printf("%lld\n", ans);
}
return 0;
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 0ms
memory: 3876kb
input:
3 8 2 4 2 4 3 4 5 3 2 3 0 6 -3 3 -3 0 -2 -3 1 -5 3 -3 4 0 3 1 2 3 0 0 1 0 0 1 3 1 1 1 0 0 1 0 0 1
output:
84 0 1
result:
ok 3 number(s): "84 0 1"
Test #2:
score: -100
Wrong Answer
time: 0ms
memory: 3932kb
input:
1 4 1000000000 1000000000 1000000000 1000000000 -1000000000 -1000000000 1000000000 -1000000000 1000000000 1000000000 -1000000000 1000000000
output:
4000000000000000000
result:
wrong answer 1st numbers differ - expected: '8000000000000000000', found: '4000000000000000000'