제출 #981162

#제출 시각아이디문제언어결과실행 시간메모리
981162Darren0724밀림 점프 (APIO21_jumps)C++17
0 / 100
9 ms31216 KiB
#include "jumps.h" #include <bits/stdc++.h> using namespace std; int n; vector<int> v,a,b,pl; int jump[20][200005]; int jump1[20][200005]; void init(int N, vector<int> H) { n=N; v=H; a.resize(n,-1); b.resize(n,-1); pl.resize(n+1); vector<int> st; for(int i=0;i<n;i++){ pl[v[i]]=i; while(st.size()&&v[st.back()]<v[i]){ st.pop_back(); } a[i]=(st.size()?st.back():-1); st.push_back(i); } st.clear(); for(int i=n-1;i>=0;i--){ while(st.size()&&v[st.back()]<v[i]){ st.pop_back(); } b[i]=(st.size()?st.back():-1); st.push_back(i); } for(int i=0;i<n;i++){ if(a[i]==-1)swap(a[i],b[i]); else if(b[i]==-1)continue; else { if(v[a[i]]<v[b[i]]){ swap(a[i],b[i]); } } } for(int j=n;j>=1;j--){ int i=pl[j]; int now=a[i]; jump[0][i]=now; for(int k=1;k<20;k++){ if(now==-1){ jump[k][i]=-1; continue; } else{ now=jump[k][i]=jump[k-1][now]; } } now=b[i]; jump1[0][i]=now; for(int k=1;k<20;k++){ if(now==-1){ jump1[k][i]=-1; continue; } else{ now=jump1[k][i]=jump1[k-1][now]; } } } } int f(int A, int C) { int ans=0; int now=A; for(int k=19;k>=0;k--){ if(v[jump[k][now]]<=v[C]){ ans+=(1<<k); now=jump[k][now]; } } for(int k=19;k>=0;k--){ if(v[jump1[k][now]]<=v[C]){ ans+=(1<<k); now=jump1[k][now]; } } if(now!=C)ans=1e9; return ans; } int minimum_jumps(int A, int B, int C, int D) { int ans=1e9; for(int i=A;i<=B;i++){ for(int j=C;j<=D;j++){ ans=min(ans,f(i,j)); } } if(ans==1e9)ans=-1; return ans; }
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...