제출 #1227246

#제출 시각아이디문제언어결과실행 시간메모리
1227246MalixText editor (CEOI24_editor)C++20
5 / 100
4091 ms5624 KiB
#include <bits/stdc++.h>
using namespace std;
 
typedef long long ll;
typedef vector<int> vi;
typedef vector<vi> vii;
typedef pair<int,int> pi;
typedef vector<pi> pii;
typedef tuple<ll,int,int> ti;
typedef vector<ll> li;
typedef vector<li> lii;
 
#define REP(i,a,b) for(int i=a;i<b;i++)
#define F first
#define S second
#define PB push_back
#define LSOne(s) ((s)&(-s))
#define all(x) (x).begin(),(x).end()
 
ll INF=1000000000000000010;
int inf=1e9+10;
ll M=1e9+7;

int main() {
    ios::sync_with_stdio(0);
    cin.tie(0);
    int n;cin>>n;
    pi P,Q;
    cin>>P.F>>P.S>>Q.F>>Q.S;
    P.F--;P.S--;Q.F--;Q.S--;
    vi b(n);
    REP(i,0,n)cin>>b[i];
    map<pi,vector<ti>> a;
    map<pi,ll> dist;
    int mn=min(P.S,Q.S),mx=max(P.S,Q.S);
    ll dif=(ll)mx-(ll)mn;
    REP(i,0,n){
        if(i!=0){
            if(b[i-1]>mx&&b[i]>mx){
                a[{i,mx}].PB({1,i-1,mx});
                a[{i-1,mx}].PB({1,i,mx});
            }
            if(b[i-1]>mn&&b[i]>mn){
                a[{i,mn}].PB({1,i-1,mn});
                a[{i-1,mn}].PB({1,i,mn});
            }
            a[{i,0}].PB({1,i-1,0});
            a[{i,0}].PB({1,i-1,b[i-1]});
            if(b[i-1]<b[i]){
                if(mx>b[i-1])a[{i,mx}].PB({1,i-1,b[i-1]});
                if(mn>b[i-1])a[{i,mn}].PB({1,i-1,b[i-1]});
                a[{i,b[i]}].PB({1,i-1,b[i-1]});
                a[{i,b[i]}].PB({b[i]-b[i-1],i,b[i-1]});
                a[{i,b[i-1]}].PB({b[i]-b[i-1],i,b[i]});
                if(b[i-1]>mx){
                    a[{i,b[i-1]}].PB({b[i-1]-mx,i,mx});
                    a[{i,mx}].PB({b[i-1]-mx,i,b[i-1]});
                }
                else if(b[i-1]>mn){
                    a[{i,b[i-1]}].PB({abs(b[i-1]-mn),i,mn});
                    a[{i,mn}].PB({abs(b[i-1]-mn),i,b[i-1]});
                    if(b[i]>mn){
                        a[{i,b[i-1]}].PB({abs(b[i-1]-mx),i,mx});
                        a[{i,mx}].PB({abs(b[i-1]-mx),i,b[i-1]});
                    }
                }
                else{
                    a[{i,b[i-1]}].PB({b[i-1],i,0});
                    a[{i,0}].PB({b[i-1],i,b[i-1]});
                    if(b[i]>mn){
                        a[{i,b[i-1]}].PB({abs(b[i-1]-mn),i,mn});
                        a[{i,mn}].PB({abs(b[i-1]-mn),i,b[i-1]});
                    }
                }
            }
            else a[{i,b[i]}].PB({1,i-1,b[i]});
        }
        if(i!=n-1){
            a[{i,0}].PB({1,i+1,0});
            a[{i,b[i]}].PB({1,i+1,0});
            if(b[i+1]<b[i]){    
                if(mx>b[i+1])a[{i,mx}].PB({1,i+1,b[i+1]});
                if(mn>b[i+1])a[{i,mn}].PB({1,i+1,b[i+1]});
                a[{i,b[i]}].PB({1,i+1,b[i+1]});
                a[{i,b[i]}].PB({b[i]-b[i+1],i,b[i+1]});
                a[{i,b[i+1]}].PB({b[i]-b[i+1],i,b[i]});
                if(b[i+1]>mx){
                    a[{i,b[i+1]}].PB({b[i+1]-mx,i,mx});
                    a[{i,mx}].PB({b[i+1]-mx,i,b[i+1]});
                }
                else if(b[i+1]>mn){
                    a[{i,b[i+1]}].PB({abs(b[i+1]-mn),i,mn});
                    a[{i,mn}].PB({abs(b[i+1]-mn),i,b[i+1]});
                    if(b[i]>mn){
                        a[{i,b[i+1]}].PB({abs(b[i+1]-mx),i,mx});
                        a[{i,mx}].PB({abs(b[i+1]-mx),i,b[i+1]});
                    }
                }
                else{
                    a[{i,b[i+1]}].PB({b[i+1],i,0});
                    a[{i,0}].PB({b[i+1],i,b[i+1]});
                    if(b[i]>mn){
                        a[{i,b[i+1]}].PB({abs(b[i+1]-mn),i,mn});
                        a[{i,mn}].PB({abs(b[i+1]-mn),i,b[i+1]});
                    }
                }
            }
            else a[{i,b[i]}].PB({1,i+1,b[i]});
        }
        a[{i,0}].PB({b[i],i,b[i]});
        a[{i,b[i]}].PB({b[i],i,0});
        if(b[i]>mx){
            a[{i,0}].PB({mn,i,mn});
            a[{i,mn}].PB({mn,i,0});
            a[{i,mx}].PB({dif,i,mn});
            a[{i,mn}].PB({dif,i,mx});
            a[{i,mx}].PB({b[i]-mx,i,b[i]});
            a[{i,b[i]}].PB({b[i]-mx,i,mx});
        }
        else if(b[i]>mn){
            a[{i,0}].PB({mn,i,mn});
            a[{i,mn}].PB({mn,i,0});
            a[{i,mn}].PB({b[i]-mn,i,b[i]});
            a[{i,b[i]}].PB({b[i]-mn,i,mn});
        }
    }
    for(auto [u,v]:a)dist[u]=INF;
    dist[P]=0;
    priority_queue<ti,vector<ti>,greater<ti>> pq;
    pq.push({0,P.F,P.S});
    while(!pq.empty()){
        auto [z,x,y]=pq.top();
        pq.pop();
        if(dist[{x,y}]<z)continue;
        for(auto u:a[{x,y}]){
            auto [p,q,r]=u;
            if(p==0)continue;
            if(dist[{q,r}]<dist[{x,y}]+p)continue;
            dist[{q,r}]=dist[{x,y}]+p;
            pq.push({dist[{q,r}],q,r});
        }
    }
    cout<<dist[Q];
}
#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...