Submission #954257

#TimeUsernameProblemLanguageResultExecution timeMemory
954257colossal_pepeJakarta Skyscrapers (APIO15_skyscraper)C++17
10 / 100
1 ms604 KiB
#include <iostream> #include <vector> #include <queue> using namespace std; int n, m; vector<int> b, p; vector<vector<int>> v; int solve() { vector<int> dist(m, -1); queue<pair<int, int>> q; dist[b[0]] = 0; q.push({b[0], 0}); while (not q.empty() and dist[1] == -1) { auto [i, j] = q.front(); q.pop(); if (not v[i].empty() and dist[v[i][0]] == -1) { for (int k : v[i]) { dist[k] = dist[j] + (abs(i - b[j]) / p[j]); q.push({i, k}); } } if (i + p[j] < n) q.push({i + p[j], j}); if (i - p[j] >= 0) q.push({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...