Submission #1017067

# Submission time Handle Problem Language Result Execution time Memory
1017067 2024-07-08T20:12:24 Z MilosMilutinovic Soccer Stadium (IOI23_soccer) C++17
15 / 100
2694 ms 812880 KB
#include "soccer.h"
#include <bits/stdc++.h>
 
using namespace std;
 
const int MAX = 2005;
const int LOG = 12;
 
int n, a[MAX][MAX];
int L[MAX][MAX];
int R[MAX][MAX];
int U[MAX][MAX];
int D[MAX][MAX];
int go[MAX][MAX];
int logs[MAX];
int st_U[MAX][MAX][LOG];
int st_D[MAX][MAX][LOG];
int res;
map<array<int, 5>, bool> was;
 
int query_U(int i, int l, int r) {
  int k = logs[r - l + 1];
  return max(st_U[i][l][k], st_U[i][r - (1 << k) + 1][k]);
}
 
int query_D(int i, int l, int r) {
  int k = logs[r - l + 1];
  return min(st_D[i][l][k], st_D[i][r - (1 << k) + 1][k]);
}
 
void rec(int xl, int xr, int yl, int yr, int side, int cur) {
  if (was[{xl, xr, yl, yr, side}]) {
    return;
  }
  res = max(res, cur);
  was[{xl, xr, yl, yr, side}] = true;
  if (xl > 0) {
    // up
    int ptr = yl;
    while (ptr <= yr) {
      if (a[xl - 1][ptr] == 1) {
        ptr = go[xl - 1][ptr];
        continue;
      }
      int t = min(yr, R[xl - 1][ptr]);
      int new_x = query_U(xl - 1, ptr, t);
      rec(xl - 1, xr, ptr, t, 1, cur + t - ptr + 1);
      ptr = R[xl - 1][ptr] + 1;
    }
  }
  if (xr + 1 < n) {
    // down
    int ptr = yl;
    while (ptr <= yr) {
      if (a[xr + 1][ptr] == 1) {
        ptr = go[xr + 1][ptr];
        continue;
      }
      int t = min(yr, R[xr + 1][ptr]);
      int new_x = query_D(xr + 1, ptr, t);
      rec(xl, xr + 1, ptr, t, 0, cur + t - ptr + 1);
      ptr = R[xr + 1][ptr] + 1;
    }
  }
}
 
int biggest_stadium(int N, vector<vector<int>> F) {
  n = N;
  for (int i = 0; i < n; i++) {
    for (int j = 0; j < n; j++) {
      a[i][j] = F[i][j];
    }
  }
  for (int i = 0; i < n; i++) {
    for (int j = 0; j < n; j++) {
      if (a[i][j] == 1) {
        continue;
      }
      int p = j;
      while (p + 1 < n && a[i][p + 1] == 0) {
        p += 1;
      }
      for (int k = j; k <= p; k++) {
        L[i][k] = j;
        R[i][k] = p;
      }
      j = p;
    }
  }
  for (int j = 0; j < n; j++) {
    for (int i = 0; i < n; i++) {
      if (a[i][j] == 1) {
        continue;
      }
      int p = i;
      while (p + 1 < n && a[p + 1][j] == 0) {
        p += 1;
      }
      for (int k = i; k <= p; k++) {
        U[k][j] = i;
        D[k][j] = p;
      }
      i = p;
    }
  }
  for (int i = 2; i <= n; i++) {
    logs[i] = logs[i >> 1] + 1;
  }
  for (int i = 0; i < n; i++) {
    for (int j = 0; j < n; j++) {
      st_U[i][j][0] = U[i][j];
      st_D[i][j][0] = D[i][j];
    }
  }
  for (int k = 1; k < LOG; k++) {
    for (int i = 0; i < n; i++) {
      for (int j = 0; j + (1 << k) <= n; j++) {
        st_U[i][j][k] = max(st_U[i][j][k - 1], st_U[i][j + (1 << (k - 1))][k - 1]);
        st_D[i][j][k] = min(st_D[i][j][k - 1], st_D[i][j + (1 << (k - 1))][k - 1]);
      }
    }
  }
  for (int i = 0; i < n; i++) {
    for (int j = n - 1; j >= 0; j--) {
      if (a[i][j] == 1) {
        go[i][j] = (j == n - 1 ? n : go[i][j + 1]);
      } else {
        go[i][j] = j;
      }
    }
  }
  res = 0;
  vector<array<int, 4>> s;
  for (int i = 0; i < n; i++) {
    for (int j = 0; j < n; j++) {
      if (a[i][j] == 1) {
        continue;
      }
      if (j == 0 || a[i][j - 1] == 1) {
        s.push_back({R[i][j] - j + 1, i, j, R[i][j]});
      }
    }
  }
  sort(s.rbegin(), s.rend());
  for (auto& p : s) {
    int i = p[1];
    int l = p[2], r = p[3];
    rec(i, i, l, r, -1, r - l + 1);
  }
  return res;
}

Compilation message

soccer.cpp: In function 'void rec(int, int, int, int, int, int)':
soccer.cpp:46:11: warning: unused variable 'new_x' [-Wunused-variable]
   46 |       int new_x = query_U(xl - 1, ptr, t);
      |           ^~~~~
soccer.cpp:60:11: warning: unused variable 'new_x' [-Wunused-variable]
   60 |       int new_x = query_D(xr + 1, ptr, t);
      |           ^~~~~
# Verdict Execution time Memory Grader output
1 Correct 2 ms 16728 KB ok
# Verdict Execution time Memory Grader output
1 Correct 2 ms 16728 KB ok
2 Correct 2 ms 16728 KB ok
3 Correct 2 ms 16732 KB ok
4 Correct 2 ms 16728 KB ok
5 Correct 2 ms 14684 KB ok
6 Correct 2 ms 16732 KB ok
7 Correct 8 ms 38396 KB ok
8 Partially correct 135 ms 118440 KB partial
9 Partially correct 2694 ms 812880 KB partial
# Verdict Execution time Memory Grader output
1 Correct 2 ms 16728 KB ok
2 Correct 2 ms 16728 KB ok
3 Correct 2 ms 16728 KB ok
4 Correct 2 ms 16732 KB ok
5 Correct 2 ms 16732 KB ok
6 Correct 2 ms 16728 KB ok
7 Correct 2 ms 16732 KB ok
8 Correct 2 ms 16864 KB ok
9 Correct 2 ms 16732 KB ok
10 Correct 2 ms 16732 KB ok
11 Correct 1 ms 16732 KB ok
12 Correct 2 ms 16732 KB ok
13 Correct 2 ms 16732 KB ok
# Verdict Execution time Memory Grader output
1 Correct 2 ms 16728 KB ok
2 Correct 2 ms 16728 KB ok
3 Correct 2 ms 16728 KB ok
4 Correct 2 ms 16728 KB ok
5 Correct 2 ms 16732 KB ok
6 Correct 2 ms 16732 KB ok
7 Correct 2 ms 16728 KB ok
8 Correct 2 ms 16732 KB ok
9 Correct 2 ms 16864 KB ok
10 Correct 2 ms 16732 KB ok
11 Correct 2 ms 16732 KB ok
12 Correct 1 ms 16732 KB ok
13 Correct 2 ms 16732 KB ok
14 Correct 2 ms 16732 KB ok
15 Correct 2 ms 16728 KB ok
16 Partially correct 2 ms 16732 KB partial
17 Partially correct 2 ms 16732 KB partial
18 Correct 2 ms 16732 KB ok
19 Correct 2 ms 16732 KB ok
20 Correct 2 ms 16732 KB ok
21 Correct 2 ms 16732 KB ok
22 Partially correct 1 ms 16732 KB partial
23 Correct 2 ms 16732 KB ok
24 Correct 2 ms 16732 KB ok
25 Partially correct 2 ms 16732 KB partial
26 Correct 1 ms 16732 KB ok
# Verdict Execution time Memory Grader output
1 Correct 2 ms 16728 KB ok
2 Correct 2 ms 16728 KB ok
3 Correct 2 ms 16728 KB ok
4 Correct 2 ms 16732 KB ok
5 Correct 2 ms 16728 KB ok
6 Correct 2 ms 16728 KB ok
7 Correct 2 ms 16732 KB ok
8 Correct 2 ms 16732 KB ok
9 Correct 2 ms 16728 KB ok
10 Correct 2 ms 16732 KB ok
11 Correct 2 ms 16864 KB ok
12 Correct 2 ms 16732 KB ok
13 Correct 2 ms 16732 KB ok
14 Correct 1 ms 16732 KB ok
15 Correct 2 ms 16732 KB ok
16 Correct 2 ms 16732 KB ok
17 Correct 2 ms 16728 KB ok
18 Partially correct 2 ms 16732 KB partial
19 Partially correct 2 ms 16732 KB partial
20 Correct 2 ms 16732 KB ok
21 Correct 2 ms 16732 KB ok
22 Correct 2 ms 16732 KB ok
23 Correct 2 ms 16732 KB ok
24 Partially correct 1 ms 16732 KB partial
25 Correct 2 ms 16732 KB ok
26 Correct 2 ms 16732 KB ok
27 Partially correct 2 ms 16732 KB partial
28 Correct 1 ms 16732 KB ok
29 Correct 2 ms 16732 KB ok
30 Partially correct 4 ms 25436 KB partial
31 Partially correct 4 ms 25180 KB partial
32 Correct 3 ms 25180 KB ok
33 Correct 3 ms 24924 KB ok
34 Incorrect 2 ms 25180 KB wrong
35 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 16728 KB ok
2 Correct 2 ms 16728 KB ok
3 Correct 2 ms 16728 KB ok
4 Correct 2 ms 16732 KB ok
5 Correct 2 ms 16728 KB ok
6 Correct 2 ms 16728 KB ok
7 Correct 2 ms 16732 KB ok
8 Correct 2 ms 16732 KB ok
9 Correct 2 ms 16728 KB ok
10 Correct 2 ms 16732 KB ok
11 Correct 2 ms 16864 KB ok
12 Correct 2 ms 16732 KB ok
13 Correct 2 ms 16732 KB ok
14 Correct 1 ms 16732 KB ok
15 Correct 2 ms 16732 KB ok
16 Correct 2 ms 16732 KB ok
17 Correct 2 ms 16728 KB ok
18 Partially correct 2 ms 16732 KB partial
19 Partially correct 2 ms 16732 KB partial
20 Correct 2 ms 16732 KB ok
21 Correct 2 ms 16732 KB ok
22 Correct 2 ms 16732 KB ok
23 Correct 2 ms 16732 KB ok
24 Partially correct 1 ms 16732 KB partial
25 Correct 2 ms 16732 KB ok
26 Correct 2 ms 16732 KB ok
27 Partially correct 2 ms 16732 KB partial
28 Correct 1 ms 16732 KB ok
29 Correct 2 ms 16732 KB ok
30 Partially correct 4 ms 25436 KB partial
31 Partially correct 4 ms 25180 KB partial
32 Correct 3 ms 25180 KB ok
33 Correct 3 ms 24924 KB ok
34 Incorrect 2 ms 25180 KB wrong
35 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 16728 KB ok
2 Correct 2 ms 16728 KB ok
3 Correct 2 ms 16728 KB ok
4 Correct 2 ms 16732 KB ok
5 Correct 2 ms 16728 KB ok
6 Correct 2 ms 14684 KB ok
7 Correct 2 ms 16732 KB ok
8 Correct 8 ms 38396 KB ok
9 Partially correct 135 ms 118440 KB partial
10 Partially correct 2694 ms 812880 KB partial
11 Correct 2 ms 16728 KB ok
12 Correct 2 ms 16732 KB ok
13 Correct 2 ms 16732 KB ok
14 Correct 2 ms 16728 KB ok
15 Correct 2 ms 16732 KB ok
16 Correct 2 ms 16864 KB ok
17 Correct 2 ms 16732 KB ok
18 Correct 2 ms 16732 KB ok
19 Correct 1 ms 16732 KB ok
20 Correct 2 ms 16732 KB ok
21 Correct 2 ms 16732 KB ok
22 Correct 2 ms 16728 KB ok
23 Partially correct 2 ms 16732 KB partial
24 Partially correct 2 ms 16732 KB partial
25 Correct 2 ms 16732 KB ok
26 Correct 2 ms 16732 KB ok
27 Correct 2 ms 16732 KB ok
28 Correct 2 ms 16732 KB ok
29 Partially correct 1 ms 16732 KB partial
30 Correct 2 ms 16732 KB ok
31 Correct 2 ms 16732 KB ok
32 Partially correct 2 ms 16732 KB partial
33 Correct 1 ms 16732 KB ok
34 Correct 2 ms 16732 KB ok
35 Partially correct 4 ms 25436 KB partial
36 Partially correct 4 ms 25180 KB partial
37 Correct 3 ms 25180 KB ok
38 Correct 3 ms 24924 KB ok
39 Incorrect 2 ms 25180 KB wrong
40 Halted 0 ms 0 KB -