이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "jumps.h"
#include <bits/stdc++.h>
using namespace std;
const int nx=2e5+5, kx=18;
int l[nx], r[nx], deg[nx], lvl[nx], pa[kx][nx], in[nx], out[nx], rt, t;
vector<int> d[nx], g[nx];
void dfs(int u)
{
in[u]=++t;
for (auto v:d[u]) dfs(v);
out[u]=t;
}
void init(int N, std::vector<int> H) {
stack<int> s;
for (int i=0; i<N; i++) l[i]=r[i]=N;
for (int i=0; i<N; i++)
{
while (!s.empty()&&H[s.top()]<H[i]) s.pop();
if (!s.empty()) l[i]=s.top(), d[s.top()].push_back(i), deg[i]++;
s.push(i);
}
while (!s.empty()) s.pop();
for (int i=N-1; i>=0; i--)
{
while (!s.empty()&&H[s.top()]<H[i]) s.pop();
if (!s.empty()) r[i]=s.top(), d[s.top()].push_back(i), deg[i]++;
s.push(i);
}
//for (int i=0; i<N; i++) cout<<"debug "<<i<<' '<<l[i]<<' '<<r[i]<<'\n';
queue<int> q;
for (int i=0; i<N; i++) if (l[i]==N&&r[i]==N) q.push(i), rt=i;
while (!q.empty())
{
auto u=q.front();
q.pop();
for (auto x:d[u]) if (--deg[x]==0) q.push(x), g[u].push_back(x);
lvl[u]=max(lvl[l[u]], lvl[r[u]])+1;
}
//for (int i=0; i<N; i++) cout<<"lvl "<<i<<' '<<lvl[i]<<'\n';
for (int i=0; i<kx; i++) pa[i][N]=N;
for (int i=0; i<N; i++) pa[0][i]=(lvl[l[i]]<lvl[r[i]])?l[i]:r[i];
for (int i=1; i<kx; i++) for (int j=0; j<N; j++) pa[i][j]=pa[i-1][pa[i-1][j]];
dfs(rt);
}
int minimum_jumps(int A, int B, int C, int D) {
if (!(in[D]<=in[A]&&out[A]<=out[D])) return -1;
int res=0;
for (int i=kx-1; i>=0; i--) if (lvl[pa[i][A]]>=lvl[D]) res+=(1<<i), A=pa[i][A];
return res+lvl[A]-lvl[D];
}
/*
7 5
3 2 1 6 4 5 7
4 4 6 6
0 0 2 2
2 2 0 0
2 2 6 6
2 2 4 4
*/
| # | 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... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |