Submission #438324

#TimeUsernameProblemLanguageResultExecution timeMemory
438324JustasZDungeons Game (IOI21_dungeons)C++17
63 / 100
5636 ms459556 KiB
#include "dungeons.h" #include <bits/stdc++.h> #define pb push_back #define x first #define y second #define all(a) a.begin(), a.end() #define sz(a) (int)a.size() #define rd() abs((int)rng()) using namespace std; using ll = long long; using ld = long double; using pii = pair<int, int>; const int maxn = 2e5 + 10; const int mod = 1e9 + 7; mt19937 rng(chrono::steady_clock::now().time_since_epoch().count()); const int LOG = 25; vector<vector<vector<ll> > >sum(LOG, vector<vector<ll> >(50001)); vector<vector<vector<ll> > >mn(LOG, vector<vector<ll> >(50001)); vector<vector<vector<int> > >jump(LOG, vector<vector<int> >(50001)); int n; vector<int>s, p, w, l; void init(int N, std::vector<int> S, std::vector<int> P, std::vector<int> W, std::vector<int> L) { n = N; s = S, p = P, w = W, l = L; s.pb(0); p.pb(0); w.pb(0); l.pb(0); for (int grp = 0; grp < LOG; grp++) { for (int i = 0; i <= n; i++) { sum[grp][i] = vector<ll>(grp + 1, 0); mn[grp][i] = vector<ll>(grp + 1, 1e18); jump[grp][i] = vector<int>(grp + 1, -1); } } w[n] = n; for (int grp = 0; grp < LOG; grp++) { int upto = 1 << grp; for (int jmp = 0; jmp < grp; jmp++) { for (int i = 0; i < n; i++) { if (jmp == 0) { int to; if (s[i] <= upto) { // definitely win sum[grp][i][0] = s[i]; to = w[i]; } else { // might win sum[grp][i][0] = p[i]; mn[grp][i][0] = s[i]; to = l[i]; } jump[grp][i][0] = to; } else { int x = jump[grp][i][jmp - 1]; if (x != -1) { sum[grp][i][jmp] = sum[grp][i][jmp - 1] + sum[grp][x][jmp - 1]; mn[grp][i][jmp] = min(mn[grp][i][jmp - 1], mn[grp][x][jmp - 1] - sum[grp][i][jmp - 1]); jump[grp][i][jmp] = jump[grp][x][jmp - 1]; } else { jump[grp][i][jmp] = -1; } } } } } } ll simulate(int x, int z) { ll cur_sum = z; int cur = x; for (int grp = 0; grp < LOG - 1; grp++) { ll group_lower_bound = 1 << grp; if (cur_sum >= group_lower_bound * 2) { continue; } if (cur_sum < group_lower_bound) { exit(3); } for (int jmp = grp; jmp >= 0; jmp--) { if (jump[grp][cur][jmp] != -1 && (cur_sum + sum[grp][cur][jmp] < group_lower_bound * 2) && (cur_sum < mn[grp][cur][jmp])) { cur_sum += sum[grp][cur][jmp]; cur = jump[grp][cur][jmp]; } } // cout << cur << " " << cur_sum << " " << jump[cur][grp][0] << " " << sum[cur][grp][0] << " " << mn[cur][grp][0] << "\n"; if (cur_sum >= s[cur]) { cur_sum += s[cur]; cur = w[cur]; } else { cur_sum += p[cur]; cur = l[cur]; } if (cur != n && cur_sum < group_lower_bound * 2) { exit(3); } // cout << "after finishing group " << grp << " we are at " << cur << " with strength " << cur_sum << "\n"; if (cur == n) { return cur_sum; } } for (int jmp = LOG - 1; jmp >= 0; jmp--) { if (jump[LOG - 1][cur][jmp] != -1 && jump[LOG - 1][cur][jmp] != n) { cur_sum += sum[LOG - 1][cur][jmp]; cur = jump[LOG - 1][cur][jmp]; } } if (cur_sum >= s[cur]) { cur_sum += s[cur]; cur = w[cur]; } else { cur_sum += p[cur]; cur = l[cur]; } return cur_sum; }
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...