Submission #935903

#TimeUsernameProblemLanguageResultExecution timeMemory
935903EJIC_B_KEDAXComparing Plants (IOI20_plants)C++17
0 / 100
4080 ms24400 KiB
#include <bits/stdc++.h> using ll = long long; using namespace std; const int N = 200200; vector<int> g[N]; int used[N], tmp1[N], tmp2[N]; int clc[330][330]; void dfs(int s, int d) { clc[d][s] = 1; for (int i : g[s]) { if (!used[i]) { dfs(i, d); } } } void init(int k, vector<int> r) { int n = r.size(); int ok = 0, last, lev = n, iter = 0; for (int i = 0; i < n; i++) { tmp1[i] = -1; tmp2[i] = -1; } while (ok < n) { last = -k; for (int i = n - 1; i > n - k; i--) { if (!r[i]) { last = i - n; break; } } vector<int> nw = r; for (int i = 0; i < n; i++) { if (!r[i]) { if (i - last >= k) { if (tmp1[i] != -1) { g[tmp1[i]].push_back(i); } if (tmp2[i] != -1) { g[tmp2[i]].push_back(i); } ok++; for (int j = i - 1; j > i - k; j--) { if (j >= 0) { nw[j]--; tmp1[j] = i; } else { nw[j + n]--; tmp1[j + n] = i; } } for (int j = i + 1; j < i + k; j++) { if (j < n) { tmp2[j] = i; } else { tmp2[j - n] = i; } } nw[i] = INT32_MAX / 2; } last = i; } } swap(nw, r); lev--; iter++; assert(iter < n + 10); } for (int i = 0; i < n; i++) { for (int j = 0; j < n; j++) { used[j] = 0; } dfs(i, i); } } int compare_plants(int x, int y) { if (clc[y][x]) { return -1; } return clc[x][y]; }
#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...