Submission #954281

#TimeUsernameProblemLanguageResultExecution timeMemory
954281colossal_pepeJakarta Skyscrapers (APIO15_skyscraper)C++17
57 / 100
299 ms2568 KiB
#include <iostream> #include <vector> #include <queue> #include <tuple> using namespace std; int n, m; vector<int> b, p; vector<vector<int>> v; int solve() { vector<int> dist(m, -1); priority_queue<tuple<int, int, int>> q; dist[b[0]] = 0; q.push({0, b[0], 0}); while (not q.empty() and dist[1] == -1) { auto [d, i, j] = q.top(); q.pop(); while (not v[i].empty()) { dist[v[i].back()] = -d; q.push(make_tuple(d, i, v[i].back())); v[i].pop_back(); } if (i >= b[j] and i + p[j] < n) q.push(make_tuple(d - 1, i + p[j], j)); if (i <= b[j] and i - p[j] >= 0) q.push(make_tuple(d - 1, i - p[j], j)); } return dist[1]; } int main() { ios_base::sync_with_stdio(false); cin.tie(NULL); cin >> n >> m; v.resize(n), b.resize(m), p.resize(m); cin >> b[0] >> p[0]; for (int i = 1; i < m; i++) { cin >> b[i] >> p[i]; v[b[i]].push_back(i); } cout << solve() << '\n'; return 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...