Submission #600290

#TimeUsernameProblemLanguageResultExecution timeMemory
600290Jarif_RahmanDungeons Game (IOI21_dungeons)C++17
63 / 100
5166 ms2097152 KiB
#include "dungeons.h" #include <bits/stdc++.h> #define pb push_back #define f first #define sc second using namespace std; typedef long long int ll; typedef string str; const int K = 43; const ll inf = 1e18; int n; vector<int> S, P, W, L; int* nxt[K][K]; ll* sum[K][K]; ll* dp[K][K]; int msb(ll x){ return 63-__builtin_clzll(x); } pair<int, ll> binlift(int nd, ll s){ if(s > dp[msb(s)][0][nd]) return {nd, s}; for(int i = K-1; i >= 0; i--) if(s <= dp[msb(s)][i][nd]) return binlift(nxt[msb(s)][i][nd], s+sum[msb(s)][i][nd]); return {-1, -1}; } void init(int _n, vector<int> _S, vector<int> _P, vector<int> _W, vector<int> _L){ n = _n, S = _S, P = _P, W = _W, L = _L; S.pb(0); P.pb(0); for(int j = 0; j < K; j++) for(int k = 0; k < K; k++){ nxt[j][k] = new int[n+1]; sum[j][k] = new ll[n+1]; dp[j][k] = new ll[n+1]; fill(nxt[j][k], nxt[j][k]+n+1, n); fill(sum[j][k], sum[j][k]+n+1, 0); fill(dp[j][k], dp[j][k]+n+1, 0); } for(int k = 0; k < K; k++) for(int i = 0; i < n; i++){ if(S[i] <= (1LL<<k)){ nxt[k][0][i] = W[i]; sum[k][0][i] = S[i]; dp[k][0][i] = inf; } else{ nxt[k][0][i] = L[i]; sum[k][0][i] = P[i]; dp[k][0][i] = S[i]-1; } } for(int k = 0; k < K; k++){ for(int p = 1; p < K; p++) for(int i = 0; i <= n; i++){ nxt[k][p][i] = nxt[k][p-1][nxt[k][p-1][i]]; sum[k][p][i] = sum[k][p-1][i]+sum[k][p-1][nxt[k][p-1][i]]; dp[k][p][i] = min(dp[k][p-1][i], dp[k][p-1][nxt[k][p-1][i]]-sum[k][p-1][i]); } } } ll simulate(int x, int z){ ll s = z; while(x != n){ tie(x, s) = binlift(x, s); if(x == n) break; if(s >= S[x]) s+=S[x], x = W[x]; else s+=P[x], x = L[x]; } return s; }
#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...