Submission #991770

#TimeUsernameProblemLanguageResultExecution timeMemory
991770stdfloatSoccer Stadium (IOI23_soccer)C++17
6 / 100
2937 ms47400 KiB
#include <bits/stdc++.h> #include "soccer.h" using namespace std; int n, mx; vector<vector<int>> a, v; void f(int x) { if (x == n * n) { for (int i = 0; i < n; i++) { for (int j = 0; j < n; j++) { if (!v[i][j]) continue; vector<vector<bool>> vis(n, vector<bool>(n)); vis[i][j] = true; for (int z = 0; z < 2; z++) { for (int k = 0; k < n; k++) { for (int l = 0; l < n; l++) { if (!vis[k][l]) continue; for (int m = l - 1; m >= 0 && v[k][m]; m--) vis[k][m] = true; for (int m = l + 1; m < n && v[k][m]; m++) vis[k][m] = true; for (int m = k - 1; m >= 0 && v[m][l]; m--) vis[m][l] = true; for (int m = k + 1; m < n && v[m][l]; m++) vis[m][l] = true; } } } for (int k = 0; k < n; k++) { for (int l = 0; l < n; l++) if (v[k][l] && !vis[k][l]) return; } } } int cnt = 0; for (auto i : v) cnt += count(i.begin(), i.end(), 1); mx = max(mx, cnt); return; } for (int i = 0; i < 2; i++) { if (i && a[x / n][x % n]) return; v[x / n][x % n] = i; f(x + 1); } } int biggest_stadium(int N, vector<vector<int>> F) { n = N; a = F; int cnt = 0; for (auto i : a) cnt += count(i.begin(), i.end(), 1); if (!cnt) return n * n; else if (cnt == 1) { for (int i = 0; i < n; i++) { for (int j = 0; j < n; j++) { if (a[i][j] == 1) return n * n - min({(n - i) * (n - j), (n - i) * (j + 1), (i + 1) * (n - j), (i + 1) * (j + 1)}); } } } v.assign(n, vector<int>(n)); f(0); return mx; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...