Submission #653232

#TimeUsernameProblemLanguageResultExecution timeMemory
653232BlagojFountain (eJOI20_fountain)C++14
30 / 100
16 ms3404 KiB
#include <bits/stdc++.h> using namespace std; typedef long long ll; typedef long double ld; #define endl '\n'; int seg[131100]; int d[100002], c[100002]; pair<int, int> f[100002][20]; void build(int k, int l, int r) { if (l == r) { seg[k] = d[l]; return; } build(k * 2, l, (l + r) / 2); build(k * 2 + 1, (l + r) / 2 + 1, r); seg[k] = max(seg[k * 2], seg[k * 2 + 1]); } int ans = INT_MAX; void search(int k, int l, int r, int i, int j, int v) { if (l > j || r < i) { return; } if (l == r && d[l] > v) { ans = min(ans, l); return; } if (i <= l && r <= j) { if (seg[k * 2] > v) { search(k * 2, l, (l + r) / 2, i, j, v); } else { if (seg[k * 2 + 1] > v) { search(k * 2 + 1, (l + r) / 2 + 1, r, i, j, v); } } return; } search(k * 2, l, (l + r) / 2, i, j, v); search(k * 2 + 1, (l + r) / 2 + 1, r, i, j, v); } int main() { ios_base::sync_with_stdio(false); cin.tie(NULL); int n, q; cin >> n >> q; for (int i = 1; i <= n; i++) { cin >> d[i] >> c[i]; } build(1, 1, n); f[n][0].second = c[n]; for (int i = n - 1; i >= 1; i--) { ans = INT_MAX; search(1, 1, n, i + 1, n, d[i]); if (ans == INT_MAX) { ans = 0; } f[i][0].first = ans; f[i][0].second = c[i]; } for (int i = n - 1; i >= 1; i--) { for (int j = 1; j < 20; j++) { f[i][j].first = f[f[i][j - 1].first][j - 1].first; f[i][j].second = f[f[i][j - 1].first][j - 1].second + f[i][j - 1].second; } } while (q--) { int r, v; cin >> r >> v; while (v > 0 && r != 0) { bool change = false; for (int j = 19; j >= 0; j--) { if (v - (f[r][j].second + 1) >= 0) { v -= f[r][j].second; r = f[r][j].first; change = true; break; } } if (!change) { break; } } cout << r << endl; } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...