Submission #430586

#TimeUsernameProblemLanguageResultExecution timeMemory
430586OzyConnecting Supertrees (IOI20_supertrees)C++17
56 / 100
318 ms22152 KiB
#include "supertrees.h" #include <bits/stdc++.h> using namespace std; #define lli int #define rep(i,a,b) for (lli i = (a); i <= (b); i++) #define repa(i,a,b) for (lli i = (a); i >= (b); i--) #define debug(a) cout << #a << " = " << a << endl; #define debugsl(a) cout << #a << " = " << a << ", "; #define MAX 1000 lli n,m,ult,pos,pp; lli visitados[MAX+2]; vector<lli> cabezas; vector<vector<lli> > planos; bool compara(lli a, lli b, lli tipo,vector<vector<lli> > &pl) { lli q,w; rep(i,0,n-1) { if (tipo == 1) { if (pl[a][i] != pl[b][i]) return false; } else { if (pl[a][i] > 0) q = 1; else q = 0; if (pl[b][i] > 0) w = 1; else w = 0; if (q != w) return false; } } return true; } int construct(std::vector<std::vector<int>> p) { n = p.size(); planos = vector< vector<lli> > (n, vector<int> (n,0)); //hacer cabezas rep(i,0,n-1) { if (visitados[i] == 0) { cabezas.push_back(i); visitados[i] = 1; rep(j,0,n-1) { if (j == i || p[i][j] != 1) continue; visitados[j] = 1; if (!compara(i,j,1,p)) return 0; else { planos[i][j] = 1; planos[j][i] = 1; } } } } m = cabezas.size(); rep(i,0,m-1) { pos = cabezas[i]; if (visitados[pos] < 2) { ult = pos; visitados[pos] = 2; rep(j,0,m-1) { pp = cabezas[j]; if (pos == pp || p[pos][pp] != 2) continue; visitados[pp] = 2; if (!compara(pos,pp,2,p)) return 0; else { planos[ult][pp] = 1; planos[pp][ult] = 1; ult = pp; } } if (pos != ult) { planos[pos][ult] = 1; planos[ult][pos] = 1; } } } build(planos); 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...