제출 #600321

#제출 시각아이디문제언어결과실행 시간메모리
600321Jarif_Rahman던전 (IOI21_dungeons)C++17
89 / 100
7139 ms1428964 KiB
#pragma GCC target ("avx2") #pragma GCC optimization ("O3") #pragma GCC optimization ("unroll-loops") #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 K1 = 20, K2 = 9; const ll inf = 1e18; const int N = 4e5+1; ll p4[21]; int n; vector<int> S, P, W, L; int nxt[K1][K2][N]; ll sum[K1][K2][N]; ll dp[K1][K2][N]; int msb(ll x){ return (63-__builtin_clzll(x))/2; } pair<int, ll> binlift(int nd, ll s){ if(s > dp[msb(s)][0][nd]) return {nd, s}; for(int i = K2-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); p4[0] = 1; for(int i = 1; i < 21; i++) p4[i] = p4[i-1]*4; for(int j = 0; j < K1; j++) for(int k = 0; k < K2; k++){ 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 < K1; k++) for(int i = 0; i < n; i++){ if(S[i] <= p4[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 < K1; k++){ for(int p = 1; p < K2; p++) for(int i = 0; i <= n; i++){ nxt[k][p][i] = nxt[k][p-1][nxt[k][p-1][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]]+ sum[k][p-1][nxt[k][p-1][nxt[k][p-1][i]]] + sum[k][p-1][nxt[k][p-1][nxt[k][p-1][nxt[k][p-1][i]]]]; dp[k][p][i] = min(dp[k][p-1][i], min(dp[k][p-1][nxt[k][p-1][i]]-sum[k][p-1][i], min( dp[k][p-1][nxt[k][p-1][nxt[k][p-1][i]]]-sum[k][p-1][i]-sum[k][p-1][nxt[k][p-1][i]], dp[k][p-1][nxt[k][p-1][nxt[k][p-1][nxt[k][p-1][i]]]]-sum[k][p-1][i] -sum[k][p-1][nxt[k][p-1][i]]- sum[k][p-1][nxt[k][p-1][nxt[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; }

컴파일 시 표준 에러 (stderr) 메시지

dungeons.cpp:2: warning: ignoring '#pragma GCC optimization' [-Wunknown-pragmas]
    2 | #pragma GCC optimization ("O3")
      | 
dungeons.cpp:3: warning: ignoring '#pragma GCC optimization' [-Wunknown-pragmas]
    3 | #pragma GCC optimization ("unroll-loops")
      |
#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...