이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#include "dungeons.h"
//#define DEBUGGING
void __print(int i) { std::cerr << i; }
void __print(const char *c) {std::cerr << c; }
void __print(long long i) { std::cerr << i; }
template<typename T>
void __print(const T& t) { std::cerr << "{"; int f = 0; for (const auto& i : t) { std::cerr << (f++ ? ", " : ""); __print(i); } std::cerr << "}"; }
void _print() { std::cerr << "]\n"; }
template<typename T, typename... V>
void _print(T t, V... v) { __print(t); if (sizeof...(v)) std::cerr << ", "; _print(v...); }
#ifdef DEBUGGING
#define debug(x...) std::cerr << "[" << (#x) << "] = ["; _print(x)
#else
#define debug(x...)
#endif
constexpr static int MXSIZE = 50001;
constexpr static int MXLOG = 25;
constexpr static int BIG = 1e9;
constexpr static int MXNUM = 1e7;
// Interval, step, current index
int blp[MXLOG][MXLOG][MXSIZE];
long long blc[MXLOG][MXLOG][MXSIZE];
int blm[MXLOG][MXLOG][MXSIZE]; // minimum needed for change
std::vector<int> s, w;
int n;
int reduce(long long a)
{
if (a > MXNUM)
return MXNUM;
return a;
}
void init(int nn, std::vector<int> ss, std::vector<int> p, std::vector<int> ww, std::vector<int> l)
{
n = nn;
s = ss;
w = ww;
for (int i = 0; i < MXLOG; i++)
{
// For numbers bigger than or equal to 1<<i but smaller than 1<<(i+1)
for (int j = 0; j < n; j++)
{
blp[i][0][j] = (s[j] <= (1<<i)) ? w[j] : l[j];
blc[i][0][j] = (s[j] <= (1<<i)) ? s[j] : p[j];
blm[i][0][j] = (s[j] <= (1<<i)) ? 1e9 : s[j];
}
blp[i][0][n] = n;
blc[i][0][n] = 0;
blm[i][0][n] = 0;
for (int j = 1; j < MXLOG; j++)
{
for (int k = 0; k <= n; k++)
{
int nxt = blp[i][j-1][k];
blp[i][j][k] = blp[i][j-1][nxt];
blc[i][j][k] = blc[i][j-1][k] + blc[i][j-1][nxt];
blm[i][j][k] = std::min(blm[i][j-1][k], std::max(0, blm[i][j-1][nxt] - reduce(blc[i][j-1][k])));
}
}
}
}
long long simulate(int x, int z)
{
for (int i = 31 - __builtin_clz(z); i < MXLOG; i++)
{
debug(i, x, z);
for (int j = MXLOG-1; j >= 0; j--)
{
if (blm[i][j][x] > z)
{
z += blc[i][j][x];
x = blp[i][j][x];
}
}
debug(i, x, z);
if (z < n && z >= s[x])
{
z += s[x];
x = w[x];
}
}
return z;
}
# | 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... |