Submission #1072898

#TimeUsernameProblemLanguageResultExecution timeMemory
1072898IgnutStations (IOI20_stations)C++17
0 / 100
1018 ms1776 KiB
// Ignut #include <bits/stdc++.h> using namespace std; using ll = long long; const int N = 1111; vector<int> tree[N]; vector<int> euler; int root; void dfs(int v, int par) { euler.push_back(v); for (int to : tree[v]) { if (to != par) { dfs(to, v); if (v == root) euler.push_back(v); } } } vector<int> label(int n, int k, vector<int> u, vector<int> v) { euler.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]); } root = 0; for (int i = 0; i < n; i ++) if (tree[i].size() > 2) root = i; dfs(root, -1); vector<int> lbl(n); lbl[root] = 0; int number = 1; for (int v : euler) { if (v == root) { number = (number / 1000 + 1) * 1000; number ++; continue; } lbl[v] = number ++; } for (int val : lbl) cerr << val << ' '; cerr << '\n'; return lbl; } int find_next_station(int s, int t, vector<int> c) { for (int val : c) cerr << val << ' '; cerr << '\n'; if (c.size() > 2) { for (int v : c) { if (v / 1000 == t / 1000) return v; } t /= 0; return t; } if (c.size() > 2) t /= 0; if (c.size() == 1) return c[0]; int mn = min(c[0], c[1]); int mx = max(c[0], c[1]); if (mn == t) return t; if (mx == t) return t; if (t == 0) return mn; t /= 0; if (mx / 1000 == t / 1000) { if (mx % 1000 < t % 1000) return mx; return mn; } if (mx / 1000 == s / 1000) return mn; s /= 0; return mx; }

Compilation message (stderr)

stations.cpp: In function 'int find_next_station(int, int, std::vector<int>)':
stations.cpp:69:11: warning: division by zero [-Wdiv-by-zero]
   69 |         t /= 0;
      |         ~~^~~~
stations.cpp:73:11: warning: division by zero [-Wdiv-by-zero]
   73 |         t /= 0;
      |         ~~^~~~
stations.cpp:85:7: warning: division by zero [-Wdiv-by-zero]
   85 |     t /= 0;
      |     ~~^~~~
stations.cpp:96:7: warning: division by zero [-Wdiv-by-zero]
   96 |     s /= 0;
      |     ~~^~~~
#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...