제출 #761533

#제출 시각아이디문제언어결과실행 시간메모리
761533caganyanmaz던전 (IOI21_dungeons)C++17
0 / 100
12 ms2516 KiB
#include <bits/stdc++.h> #define pb push_back using namespace std; constexpr static int SIZE = 400001; constexpr static int LOG_SIZE = 30; constexpr static int DIFF = 6; // Smaller than all, bigger than 1 2 3 4 5 int64_t gain[SIZE][DIFF][LOG_SIZE]; int nxt[SIZE][DIFF][LOG_SIZE]; vector<int> ds, s, p, w, l; int m, n; int gi(int val) { return upper_bound(ds.begin(), ds.end(), val) - ds.begin(); } void init(int nn, vector<int> ss, vector<int> pp, vector<int> ww, vector<int> ll) { n = nn; s = ss, p = pp, w = ww, l = ll; set<int> dss; for (int i : s) dss.insert(i); assert(dss.size() < DIFF); for (int i : dss) ds.pb(i); m = ds.size(); p.pb(0), s.pb(0), w.pb(n), l.pb(n); for (int i = 0; i <= n; i++) { for (int j = 0; j <= m; j++) { if (gi(s[i]) > j) { gain[i][j][0] = p[i]; nxt[i][j][0] = l[i]; } else { gain[i][j][0] = s[i]; nxt[i][j][0] = w[i]; } } } for (int i = 1; i < LOG_SIZE; i++) { for (int j = 0; j <= n; j++) { for (int k = 0; k <= m; k++) { nxt[j][k][i] = nxt[nxt[j][k][i-1]][k][i-1]; gain[j][k][i] = gain[j][k][i-1] + gain[nxt[j][k][i-1]][k][i-1]; } } } } int64_t simulate(int x, int zz) { int64_t z = zz; while (x != n) { int _next = LOG_SIZE -1; int ci = gi(z); if (ci < m-1) while (_next >= 0 && (gain[x][ci][_next] + z) >= ds[ci+1]) _next--; if (_next >= 0) { z += gain[x][ci][_next]; x = nxt[x][ci][_next]; } if (z >= s[x]) { z += s[x]; x = w[x]; } else { z += p[x]; x = l[x]; } } return z; }
#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...