Submission #1035476

#TimeUsernameProblemLanguageResultExecution timeMemory
1035476vjudge1Comparing Plants (IOI20_plants)C++14
0 / 100
1225 ms2097152 KiB
#include "plants.h" #include <bits/stdc++.h> using namespace std; const int N = 200'010; vector<int> g[N]; int n; bool vis[N]; vector<int> topo; vector<bitset<N>> b(N); void dfs(int at) { vis[at]=1; for(int to:g[at]) { if(vis[to])continue; dfs(to); } if(at < n) topo.push_back(at); } void init(int k, std::vector<int> r) { n=r.size(); int dummy=n; int idx=-1; for(int i = 0;i<n;i++) { if(r[i] == 0) { idx=i; break; } } vector<int> nums; nums.push_back(idx); vector<int> tim(n+k+1, -1e9); tim[idx]=0; for(int j = (idx+1)%n, cnt=0;cnt+1<k;j=(j+1)%n, cnt++) { g[idx].push_back(j); tim[dummy]=cnt+1; nums.push_back(dummy++); } for(int j = 0;j+1<(int)nums.size();j++) { g[nums[j]].push_back(nums[j+1]); } int timer=-1; for(int j = (idx-1+n)%n;j!=idx;j=(j-1+n)%n) { int need_to_erase=0; for(int i = 0;i<n+k;i++){ if(tim[i] == timer+k) { need_to_erase=i; break; } } for(auto it=nums.begin();it!=nums.end();it++) { if((*it) == need_to_erase) { nums.erase(it); break; } } auto it = nums.insert(nums.begin()+r[j], j); if(it!=nums.begin()) { g[(*prev(it))].push_back(j); } if(it!=(--nums.end())) { g[j].push_back((*next(it))); } tim[j]=timer; timer--; } for(int i = 0;i<n;i++) { if(!vis[i]) dfs(i); b[i][i]=1; } for(int i:topo) { for(int j:g[i]) { b[i]|=b[j]; } } return; } int compare_plants(int x, int y) { if(b[x][y])return 1; if(b[y][x])return -1; return 0; }
#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...