Submission #300350

#TimeUsernameProblemLanguageResultExecution timeMemory
300350ElegiaConnecting Supertrees (IOI20_supertrees)C++17
96 / 100
262 ms22264 KiB
#include "supertrees.h" #include <functional> #include <vector> #include <iostream> using namespace std; int construct(vector<vector<int>> p) { int n = p.size(); vector<vector<int>> answer(n, vector<int>(n)); vector<int> vis(n, -1); int cur = 0, mask = 0; function<void(int)> dfs = [&](int u) { vis[u] = cur; for (int v = 0; v < n; ++v) if (vis[v] == -1 && ((mask >> p[u][v]) & 1)) dfs(v); }; mask = 14; for (int i = 0; i < n; ++i) if (vis[i] == -1) { cur = i; dfs(i); } for (int i = 0; i < n; ++i) for (int j = 0; j < n; ++j) if (vis[i] == vis[j] && !p[i][j]) return 0; mask = 2; auto vis2 = vis; vis.assign(n, -1); for (int i = 0; i < n; ++i) if (vis[i] == -1) { cur = i; dfs(i); } for (int i = 0; i < n; ++i) for (int j = 0; j < n; ++j) if (vis[i] == vis[j] && p[i][j] == 2) return 0; vector<int> cand(n, -1); vector<vector<int>> cycs(n); for (int i = 0; i < n; ++i) { if (cand[vis[i]] == -1) { cand[vis[i]] = i; cycs[vis2[i]].push_back(i); } else { answer[cand[vis[i]]][i] = answer[i][cand[vis[i]]] = 1; } } for (int i = 0; i < n; ++i) for (int j = 0; j < n; ++j) if (vis[i] != vis[j] && p[cand[vis[i]]][cand[vis[j]]] != p[i][j]) return 0; for (auto cyc : cycs) { if (cyc.size() > 1) { int val = p[cyc[0]][cyc[1]]; if (val == 2) { if (cyc.size() < 3) return 0; answer[cyc[0]][cyc.back()] = answer[cyc.back()][cyc[0]] = 1; for (int i = 1; i < cyc.size(); ++i) answer[cyc[i - 1]][cyc[i]] = answer[cyc[i]][cyc[i - 1]] = 1; } else { if (cyc.size() < 4) return 0; answer[cyc[0]][cyc.back()] = answer[cyc.back()][cyc[0]] = 1; answer[cyc[0]][cyc[2]] = answer[cyc[2]][cyc[0]] = 1; for (int i = 1; i < cyc.size(); ++i) answer[cyc[i - 1]][cyc[i]] = answer[cyc[i]][cyc[i - 1]] = 1; } } } build(answer); return 1; }

Compilation message (stderr)

supertrees.cpp: In function 'int construct(std::vector<std::vector<int> >)':
supertrees.cpp:61:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   61 |     for (int i = 1; i < cyc.size(); ++i)
      |                     ~~^~~~~~~~~~~~
supertrees.cpp:67:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   67 |     for (int i = 1; i < cyc.size(); ++i)
      |                     ~~^~~~~~~~~~~~
#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...