Submission #372845

#TimeUsernameProblemLanguageResultExecution timeMemory
372845OzyStations (IOI20_stations)C++17
100 / 100
1055 ms1408 KiB
#include "stations.h" #include <bits/stdc++.h> using namespace std; #define rep(i,a,b) for (int i = (a); i <= (b); i++) #define repa(i,a,b) for (int i = (a); i >= (b); i--) #define lli int #define debug(a) cout << #a << ' ' << a << endl lli cont,tam; vector<lli> hijos[1002],res; void llena(lli pos, lli padre, lli pp) { if (pp == 1) res[pos] = cont++; for (auto h : hijos[pos]) { if (h == padre) continue; if (pp == 1) llena(h,pos,0); else llena(h,pos,1); } if (pp == 0) res[pos] = cont++; } std::vector<int> label(int n, int k, std::vector<int> u, std::vector<int> v) { res.clear(); res.resize(n); rep(i,0,n-1) hijos[i].clear(); rep(i,0,n-2) { hijos[u[i]].push_back(v[i]); hijos[v[i]].push_back(u[i]); } cont = 0; llena(0,-1,1); return res; } int find_next_station(int s, int t, std::vector<int> c) { int ini,fin; ini = c[0]; fin = c[c.size()-1]; if (ini > s) { if (t < s) return fin; if (t > fin) return fin; for (auto h : c) { if (t <= h) return h; } } else { if (t > s) return ini; if (t < ini) return ini; tam = c.size()-1; repa(i,tam,0) { if (t >= c[i]) return c[i]; } } return s; }
#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...