Submission #1072956

#TimeUsernameProblemLanguageResultExecution timeMemory
1072956IgnutStations (IOI20_stations)C++17
5 / 100
617 ms936 KiB
// Ignut #include <bits/stdc++.h> using namespace std; using ll = long long; const int N = 1111; vector<int> tree[N]; vector<int> order; void dfs(int v, int par) { order.push_back(v); for (int to : tree[v]) if (to != par) dfs(to, v); } vector<int> label(int n, int k, vector<int> u, vector<int> v) { order.clear(); for (int i = 0; i < n; i ++) { tree[i].clear(); } for (int i = 0; i < n - 1; i ++) { tree[u[i]].push_back(v[i]); tree[v[i]].push_back(u[i]); } int start = 0; for (int i = 0; i < n; i ++) if (tree[i].size() == 1) start = i; dfs(start, -1); vector<int> lbl(n); for (int i = 0; i < n; i ++) lbl[order[i]] = i; return lbl; } int find_next_station(int s, int t, vector<int> c) { if (c.size() == 1) return c[0]; int mn = min(c[0], c[1]); int mx = max(c[0], c[1]); if (s < t) return mx; return mn; }
#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...