답안 #892965

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
892965 2023-12-26T09:17:45 Z abcvuitunggio 고대 책들 (IOI17_books) C++17
0 / 100
2000 ms 2396 KB
#include "books.h"
#include <bits/stdc++.h>
using namespace std;
int vis[1000001],r[1000001],g[1000001],nxt[1000001];
vector <pair <int, pair <int, int>>> e;
long long minimum_walk(vector <int> p, int s){
    int n=p.size(),lo=n,hi=0;
    iota(nxt,nxt+n,0);
    vector <pair <int, int>> tmp;
    long long d=0;
    for (int i=0;i<n;i++)
        if (!vis[i]){
            int x=i;
            while (!vis[x]){
                vis[x]=1;
                g[x]=i;
                r[i]=max(r[i],x);
                d+=abs(x-p[x]);
                x=p[x];
            }
          	if (r[i]!=i||i==s){
                lo=min(lo,i);
                hi=max(hi,r[i]);
          	}
        }
    int L=g[s],R=r[g[s]];
    while (L>lo||R<hi){
        if (nxt[L]!=R){
            int j=nxt[L]+1;
            nxt[L]=nxt[j];
            L=min(L,g[j]);
            R=max(R,r[g[j]]);
            continue;
        }
        int tmpl=L,tmpr=R;
        while (L>=lo&&R<=hi){
            d+=2;
            L=max(L-1,lo);
            R=min(R+1,hi);
            int newL=g[L],newR=r[g[R]],ch=0;
            while (L>newL){
                if (L>=lo&&r[g[L]]>tmpr){
                    L=g[L];
                    R=r[g[L]];
                    ch=1;
                    break;
                }
                L--;
            }
            if (ch)
                break;
            ch=0;
            while (R<newR){
                if (R<=hi&&g[R]<tmpl){
                    L=g[R];
                    R=r[g[R]];
                    ch=1;
                    break;
                }
                R++;
            }
            if (ch)
                break;
        }
    }
    return d;
}
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 2061 ms 2396 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 2061 ms 2396 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 2061 ms 2396 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 1 ms 2396 KB 3rd lines differ - on the 1st token, expected: '3304', found: '3310'
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 2061 ms 2396 KB Time limit exceeded
2 Halted 0 ms 0 KB -