Submission #1061913

#TimeUsernameProblemLanguageResultExecution timeMemory
1061913vjudge1Comparing Plants (IOI20_plants)C++17
0 / 100
4032 ms54344 KiB
#include "plants.h" #include <bits/stdc++.h> using namespace std; using vi = vector<int>; vector<vi> L; vi dfs(int u0) { int n = int(L.size()); vi viz(n, 0); function<void(int)> dfs0 = [&](int u) { if(viz[u]) return; viz[u] = 1; for(auto it : L[u]) { if(it != u) dfs0(it); } }; dfs0(u0); return viz; } vector<vi> Reach; vi perm0, invp0, inv2p0; void init(int k, vi r) { int n = int(r.size()); vi active(n, 1); L.resize(n); set<int> Zero; for(int i = 0; i < n; ++i) if(!r[i]) Zero.insert(i); for(int i = 0; i < n; ++i) { int v = 0; for(auto it : Zero) { int ok = 1; for(int j = 1; j < k; ++j) { int p = (it - j + n) % n; if(active[p] && !r[p]) { ok = 0; break; } } if(ok) { v = it; break; } } Zero.erase(v); active[v] = 0; for(int j = 1; j < k; ++j) { int p = (v - j + n) % n; if(active[p]) { --r[p]; if(!r[p]) { L[v].push_back(p); Zero.insert(p); } } ///^ oare si fara !r[p] e ok rationamentul int p2 = (v + j) % n; if(active[p2]) { L[v].push_back(p2); /// nu puteau fi popite } } perm0.push_back(v); } reverse(perm0.begin(), perm0.end()); invp0.resize(n); inv2p0.resize(n); for(int i = 0; i < n; ++i) { invp0[perm0[i]] = i; } for(int i = 0; i < n; ++i) inv2p0[invp0[i]] = i; for(int i = 0; i < n; ++i) for(int i = 0; i < n; ++i) { sort(L[i].begin(), L[i].end()); L[i].resize(unique(L[i].begin(), L[i].end()) - L[i].begin()); } if(n <= 1) { for(int i = 0; i < n; ++i) Reach.push_back(dfs(i)); } } int compare_plants(int x, int y) { if(!Reach.empty()) { if(Reach[x][y]) return 1; if(Reach[y][x]) return -1; return 0; } else { if(invp0[x] < invp0[y]) return -1; return 1; } }
#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...