제출 #862666

#제출 시각아이디문제언어결과실행 시간메모리
862666hjroh0315Xylophone (JOI18_xylophone)C++17
0 / 100
1 ms600 KiB
#include<bits/stdc++.h> #include"xylophone.h" using namespace std; using ll=long long; const ll inf=1e18; void solve(int N) { vector<ll>D1(N),D2(N),dist(N+1,inf); for(ll i=1;i<N;i++)D1[i]=query(i,i+1); for(ll i=2;i<N;i++)D2[i]=query(i-1,i+1); vector<array<ll,3>>edge; for(ll i=1;i<N;i++)edge.push_back(array{i,i+1,D1[i]}); for(ll i=2;i<N;i++)if(D2[i]!=D1[i-1]+D1[i])edge.push_back(array{i-1,i+1,abs(D1[i]-D1[i-1])}); dist[1]=0; for(ll t=0;t<N;t++) for(auto[u,v,w]:edge) { dist[v]=min(dist[v],dist[u]+w); dist[u]=min(dist[u],dist[v]+w); } ll mn=inf; for(ll i=1;i<=N;i++)mn=min(mn,dist[i]); for(ll i=1;i<=N;i++)dist[i]+=mn+1; mn=inf; ll mi=-1,mx=-inf,mxi=-1; for(ll i=1;i<=N;i++) { if(mn>dist[i]){mn=dist[i];mi=i;} if(mx<dist[i]){mx=dist[i];mxi=i;} } if(mi>mxi)reverse(begin(dist)+1,end(dist)); for(ll i=1;i<=N;i++)answer(i,dist[i]); }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...