Код: Выделить всё
int select(int i, vector& n) {
int pivot = medianOfMedians(n);
vector k = partition(n, pivot); // k[0] is the left part of the partitioned vector, k[1] is the right
if (i == k[0].size() + 1) {
return pivot;
} else {
if (i < k[0].size() + 1) {
return select(i, k[0]);
} else {
return select(i - k[0].size() - 1, k[1]);
}
}
}
Подробнее здесь: https://stackoverflow.com/questions/791 ... y-is-wrong
Мобильная версия