Submission #372454

#TimeUsernameProblemLanguageResultExecution timeMemory
372454Lam_lai_cuoc_doiAirline Route Map (JOI18_airline)C++17
100 / 100
889 ms25464 KiB
#include <bits/stdc++.h> #include "Alicelib.h" using namespace std; #define bit(i, x) (((x) >> (i)) & 1) void Alice(int n, int m, int a[], int b[]) { vector<pair<int, int>> s; for (int i = 0; i < m; ++i) s.emplace_back(a[i], b[i]); for (int j = 0; j < 10; ++j) { for (int i = 0; i < n; ++i) if (bit(j, i)) s.emplace_back(n + j, i); if (j + 1 < 10) s.emplace_back(n + j, n + j + 1); } for (int i = 0; i < n; ++i) s.emplace_back(n + 10, i); for (int i = 0; i < n + 10; ++i) s.emplace_back(n + 11, i); InitG(n + 12, s.size()); int pos(0); for (auto i : s) MakeG(pos++, i.first, i.second); }
#include <bits/stdc++.h> #include "Boblib.h" using namespace std; #define bit(i, x) (((x) >> (i)) & 1) void Bob(int n, int m, int a[], int b[]) { int ten(-1), elv(-1), nin(-1), zer(-1); vector<vector<bool>> adj(n, vector<bool>(n, 0)); vector<pair<int, int>> s; vector<int> cnt(n), real(n), son(n), obit, dep(n), pos(10), tmp; for (int i = 0; i < m; ++i) { adj[a[i]][b[i]] = 1; ++cnt[a[i]]; adj[b[i]][a[i]] = 1; ++cnt[b[i]]; } /// Find elevent and ten for (int i = 0; i < n; ++i) if (cnt[i] == n - 2) { for (int j = 0; j < n; ++j) if (i != j && !adj[i][j] && cnt[j] == n - 12) { ten = j; elv = i; break; } if (ten != -1) break; } /// find bit auto bfs = [&](int v) { fill(dep.begin(), dep.end(), 0); dep[v] = 1; queue<int> q; q.emplace(v); while (q.size()) { int c = q.front(); q.pop(); pos[dep[c] - 1] = c; for (auto i : obit) if (!dep[i] && adj[c][i]) { ++son[c]; q.emplace(i); dep[i] = dep[c] + 1; } } }; for (int i = 0; i < n; ++i) if (i != elv && i != ten && !adj[ten][i]) obit.emplace_back(i); bfs(obit[0]); for (auto i : obit) if (son[i] == 0) tmp.emplace_back(i); if (tmp.size() == 1) bfs(cnt[tmp.back()] > cnt[obit[0]] ? tmp.back() : obit[0]); else bfs(cnt[tmp[0]] > cnt[tmp[1]] ? tmp[0] : tmp[1]); for (int i = 0; i < 10; ++i) { for (int j = 0; j < n; ++j) if (adj[pos[i]][j]) real[j] |= 1 << i; } for (int i = 0; i < n; ++i) if (adj[ten][i]) for (int j = i + 1; j < n; ++j) if (adj[i][j] && adj[ten][j]) s.emplace_back(real[i], real[j]); InitMap(n - 12, s.size()); for (auto i : s) MakeMap(i.first, i.second); }

Compilation message (stderr)

Bob.cpp: In function 'void Bob(int, int, int*, int*)':
Bob.cpp:8:27: warning: unused variable 'nin' [-Wunused-variable]
    8 |     int ten(-1), elv(-1), nin(-1), zer(-1);
      |                           ^~~
Bob.cpp:8:36: warning: unused variable 'zer' [-Wunused-variable]
    8 |     int ten(-1), elv(-1), nin(-1), zer(-1);
      |                                    ^~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...