# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
1044482 | totoro | Ancient Books (IOI17_books) | C++17 | 0 ms | 0 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
// SOLVED SUBTASK 1 (12 pts)
// SOLVED SUBTASK 2 (10 pts)
// SOLVED SUBTASK 3 (28 pts)
// UNSOLVED SUBTASK 4 (20 pts)
// UNSOLVED SUBTASK 5 (30 pts)
// [+-+]----------------------
// TOTAL 50/100 pts
#include "books.h"
struct Component {
int start;
int end;
Component(int start, int end) : start(start), end(end) {}
};
long long sum_cycles(Component& component, std::vector<int>& p) {
std::vector<bool> visited(p.size(), false);
long long sum = 0;
for (int i = component.start; i <= component.end; ++i) {
int current = i;
while (!visited[current]) {
visited[current] = true;
long long diff = std::abs(current - p[current]);
sum += diff;
current = p[current];
}
}
return sum;
}
long long minimum_walk(std::vector<int> p, int s) {
bool already_sorted = true;
size_t first_unsolved = 0;
for (size_t i = 0; i < p.size(); ++i) {
if (i != p[i]) {
already_sorted = false;
first_unsolved = i;
break;
}
}
if (already_sorted) {
return 0;
}
size_t last_unsolved = p.size() - 1;
for (int i = p.size() - 1; i >= 0; --i) {
if (i != p[i]) {
last_unsolved = i;
break;
}
}
std::vector<Component> components;
int block_start = 0;
int block_end = 0;
bool in_block = false;
size_t distances = 0;
for (size_t i = first_unsolved; i <= last_unsolved; ++i) {
if (i == p[i] && !in_block) {
++distances;
continue;
}
if (!in_block) {
block_start = i;
block_end = p[i];
in_block = true;
} else {
block_end = std::max(block_end, p[i]);
}
if (i == block_end) {
components.emplace_back(block_start, block_end);
in_block = false;
}
}
size_t final_distances = 2 * (distances + components.size() - 1);
if (s < first_unsolved) {
final_distances += 2 * (first_unsolved - s);
} else if (s > last_unsolved) {
final_distances += 2 * (s - last_unsolved);
}
size_t sum = final_distances;
for (auto& component : components) {
sum += sum_cycles(component, p);
}
return sum;
}