제출 #438249

#제출 시각아이디문제언어결과실행 시간메모리
438249CyanForces던전 (IOI21_dungeons)C++17
11 / 100
909 ms1048580 KiB
#include "dungeons.h" #include <bits/stdc++.h> using namespace std; #define rep(i, a, b) for(int i = a; i < (b); ++i) #define all(x) begin(x), end(x) #define sz(x) (int)(x).size() #define debug(...) //ignore typedef long long ll; typedef pair<int, int> pii; typedef vector<int> vi; typedef long double ld; int n; vi s, p, w, l; ll LG1 = 27; struct T { int node; ll gain; int max_strength; }; T f(T a, T b) { T res; res.node = b.node; res.gain = a.gain + b.gain; ll x = min<ll>(a.max_strength, b.max_strength - a.gain); if(x < 0) x = -1; res.max_strength = x; return res; } vector<vector<vector<T>>> jmp; void ini() { jmp.resize(LG1); rep(a,0,LG1) { ll z = 1LL<<a; jmp[a].assign(log2(z)+1, vector<T>(n+1)); rep(i,0,n) { if(z >= s[i]) jmp[a][0][i] = T{w[i], ll(s[i]), int(1e9)}; else jmp[a][0][i] = T{l[i], ll(p[i]), s[i]-1}; } jmp[a][0][n] = T{n, ll(0), -1}; // immediately loose when enter node n rep(k,1,sz(jmp[a])) rep(i,0,n+1) jmp[a][k][i] = f(jmp[a][k-1][i], jmp[a][k-1][jmp[a][k-1][i].node]); } } ll sim(int x, ll z, int a) { if(x == n) return z; assert(z >= (1LL<<a)); assert(a < LG1); if(z >= (1LL<<(a+1))) return sim(x,z,a+1); for(int k = sz(jmp[a]); k--;) { if(x == n) return z; auto v = jmp[a][k][x]; if(z <= v.max_strength) { z += v.gain; x = v.node; } } if(x == n) return z; if(z >= (1LL<<(a+1))) return sim(x,z, a+1); assert(z >= s[x]); // we loose assert(z+s[x] >= (1LL << (a+1))); return sim(w[x], z+s[x], a); } 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; ini(); return; } ll simulate(int x, int z) { return sim(x,z,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...
#Verdict Execution timeMemoryGrader output
Fetching results...