Submission #302089

#TimeUsernameProblemLanguageResultExecution timeMemory
302089arthurconmyConnecting Supertrees (IOI20_supertrees)C++14
96 / 100
263 ms30200 KiB
#include <bits/stdc++.h> using namespace std; #ifndef ARTHUR_LOCAL #include "supertrees.h" #endif #define len(x) int((x).size()) #ifdef ARTHUR_LOCAL void build(vector<vector<int>> V) { for(auto row:V) { for(auto thing:row) cout << thing << " "; cout << endl; } } #endif vector<int> comp; vector<int> adj[1001]; bool vis[1001]; void dfs(int v) { vis[v]=1; comp.push_back(v); for(auto u:adj[v]) { if(vis[u]) continue; dfs(u); } } int construct(vector<vector<int>> P) { int n = (int)P.size(); vector<vector<int>> answer; vector<vector<int>> categ; for (int i = 0; i < n; i++) { vector<int> row(n); answer.push_back(row); categ.push_back(row); } for(int i=0; i<n; i++) { for(int j=i+1; j<n; j++) { if(P[i][j] == 1) { adj[i].push_back(j); adj[j].push_back(i); } } } vector<int> heads; vector<vector<int>> headcomps; vector<int> my_head(n+1); for(int i=0; i<n; i++) { if(vis[i]) continue; comp.clear(); dfs(i); int m = (int)comp.size(); heads.push_back(i); headcomps.push_back(comp); my_head[i]=i; for(int k=0; k<m; k++) { for(int j=i+1; j<m; j++) { if(P[comp[k]][comp[j]] != 1) return 0; } } for(int j=1; j<m; j++) { my_head[comp[j]]=i; answer[comp[0]][comp[j]]=1; answer[comp[j]][comp[0]]=1; // answer[comp[i]][comp[(i+1)%m]]=1; // answer[comp[(i+1)%m]][comp[i]]=1; } } vector<bool> headvis(n+1); vector<int> head_group(n+1); // vector<in for(int i=0; i<len(heads); i++) { if(headvis[i]) continue; headvis[i]=1; head_group[heads[i]]=heads[i]; vector<int> cur = {heads[i]}; for(int j=i+1; j<len(heads); j++) { if(P[heads[i]][heads[j]] == 2) { head_group[heads[j]]=heads[i]; cur.push_back(heads[j]); headvis[j]=1; } } // for(auto c:cur) cout << c << " "; // cout << endl; if(len(cur)==1) continue; if(len(cur)==2) return 0; for(int j=0; j<len(cur); j++) { answer[cur[j]][cur[(j+1)%len(cur)]]=1; answer[cur[(j+1)%len(cur)]][cur[j]]=1; } } for(int i=0; i<n; i++) { for(int j=0; j<n; j++) { if(P[i][j] == 0) { if(head_group[my_head[i]] == head_group[my_head[j]]) return 0; } if(P[i][j] == 2) { if(head_group[my_head[i]] != head_group[my_head[j]]) return 0; } } } build(answer); return 1; } #ifdef ARTHUR_LOCAL int main() { construct({{1,2,2,0},{2,1,2,0},{2,2,1,0},{0,0,0,1}}); } #endif
#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...