제출 #804528

#제출 시각아이디문제언어결과실행 시간메모리
804528Benmath고대 책들 (IOI17_books)C++14
12 / 100
1 ms344 KiB
#include "books.h" #include <bits/stdc++.h> using namespace std; long long minimum_walk(std::vector<int> p, int s) { long long int sum=0; int n=p.size(); int vis[n]; for(int i=0;i<n;i++){ vis[i]=0; } long long int sad=0; vector<pair<int,int> >v; for(int i=0;i<n;i++){ if(vis[i]==0 and i!=p[i]){ int maxi=i; sad=i; int i1=i; int t1=0; long long int iduci=p[i]; long long int tren=i; while(t1==0){ sum=sum+abs(iduci-tren); vis[tren]++; if(tren>maxi){ maxi=tren; } tren=iduci; iduci=p[tren]; if(tren==i1){ break; } } v.push_back({i,maxi}); } } sad=0; for(int i=v.size()-1;i>=0;i--){ int x=v[i].first; int t1=0; for(int j=i-1;j>=0;j--){ if(v[j].first<=x and v[j].second>=x){ t1++; } } if(t1==0){ sad=x; break; } } sum=sum+2*sad; return sum; }
#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...