제출 #448469

#제출 시각아이디문제언어결과실행 시간메모리
448469zxcvbnmJakarta Skyscrapers (APIO15_skyscraper)C++14
0 / 100
106 ms236612 KiB
#include <bits/stdc++.h> using namespace std; using ll = long long; const int nax = 30005; const int INF = 1e9 + 5; vector<int> dog[nax]; vector<int> jump(nax); int dp[2005][nax]; int n, m; int go(int sky, int doge) { int& ret = dp[sky][doge]; if (ret != -1) { return ret; } if (doge == 1) return ret = 0; ret = INF; // pass news for(int i : dog[sky]) { ret = min(ret, go(sky, i)); } // jump left if (sky - jump[doge] >= 0) { ret = min(ret, 1+go(sky-jump[doge], doge)); } // jump left if (sky + jump[doge] < n) { ret = min(ret, 1+go(sky+jump[doge], doge)); } return ret; } int main() { ios_base::sync_with_stdio(false); cin.tie(nullptr); memset(dp, -1, sizeof dp); cin >> n >> m; int boss = 0; for(int i = 0; i < m; i++) { int idx, p; cin >> idx >> p; dog[idx].push_back(i); jump[i] = p; if (i == 0) { boss = idx; } } cout << go(boss, 0) << "\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...