This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#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;
int gain;
int max_strength;
};
const int inf = 2e7;
T f(T a, T b) {
T res;
res.node = b.node;
res.gain = a.gain + b.gain;
if(res.gain >= inf) res.gain = inf;
res.max_strength = min(res.max_strength, b.max_strength - a.gain);
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], s[i], inf};
else jmp[a][0][i] = T{l[i], p[i], s[i]-1};
}
jmp[a][0][n] = T{n, 0, -inf}; // 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); }
Compilation message (stderr)
dungeons.cpp: In function 'void ini()':
dungeons.cpp:30:5: warning: 'res.T::max_strength' may be used uninitialized in this function [-Wmaybe-uninitialized]
30 | T res;
| ^~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |