제출 #418892

#제출 시각아이디문제언어결과실행 시간메모리
418892JediMaster11Split the Attractions (IOI19_split)C++17
0 / 100
2077 ms15008 KiB
#include <bits/stdc++.h> using namespace std; #define ll long long #define vint vector<int> #define vll vector<long long> #define fo(a, b, c) for (int a = b; a < (int)c; a++) #define rfo(a, b, c) for (int a = b - 1; a >= (int)c; a--) #define print(x) cout << x << "\n" vint subtask1(int n, int a, int b, int c, vll roads[]) { vint ans; ans.assign(n, 0); int count = 0; int prev = -1; int on = 0; int setOn = 0; vint lims; lims.push_back(a); lims.push_back(b); lims.push_back(c); do { count++; ans[on] = setOn + 1; if (count == lims[setOn]) { setOn++; count = 0; } for (auto x : roads[on]) { if (x != prev) { prev = on; on = x; break; } } } while (on != 0); return ans; } vint subtask2(int n, int a, int b, int c, vll roads[]) { vint ans; int limit = 0, changeto = 0; if (b > c) { //do C ans.assign(n, 2); limit = c; changeto = 3; } else { ans.assign(n, 3); limit = b; changeto = 2; } //find b nodes connected, then change a random different node to a, let the rest be c set<int> visited; deque<int> toVisit; // node to visit int count = 0; toVisit.push_back(0); int on = -1; int prev = -1; while (count < limit) { while (toVisit.size() > 0) { prev = on; on = toVisit.back(); toVisit.pop_back(); visited.insert(on); count++; ans[on] = changeto; break; } for (auto x : roads[on]) { if (x != prev && visited.count(x) == 0) { toVisit.push_back(x); } } } ans[toVisit.back()] = 1; return ans; } // n - number of attractions // a, b, c - size of sets a, b, c // p, q - length m arrays containing the starts and stops of all the roads //return an array of length n, all zeros if not possible, otherwise 1, 2 or 3 in each space vint find_split(int n, int a, int b, int c, vint p, vint q) { vint ans; vll roads[n]; fo(i, 0, p.size()) { roads[p[i]].push_back(q[i]); roads[q[i]].push_back(p[i]); } if (a == 1) { ans = subtask2(n, a, b, c, roads); } else { ans = subtask1(n, a, b, c, roads); } return ans; }
#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...