UPC/3sem/data structures and algos/05/protecc.cpp
2020-10-20 13:27:32 +07:00

110 lines
2.5 KiB
C++

// dsaa_05.cpp
// Горбацевич Андрей
#include <iostream>
#include <vector>
#include <chrono>
#include <cmath>
#include <cassert>
#include <algorithm>
#include <functional>
inline void time_passed(std::chrono::system_clock::time_point start, double &holder) {
auto stop = std::chrono::high_resolution_clock::now();
auto duration = std::chrono::duration_cast<std::chrono::microseconds>(stop - start);
holder = duration.count();
}
typedef double num_type;
typedef std::vector<num_type> num_list;
void test();
void algo_01(num_list &cont); // Stupid sort
void algo_02(num_list &cont); // Shell sort
int main() {
test();
return 0;
}
void test() {
int n;
std::cout << "Count of items:\n";
std::cin >> n;
num_list data;
data.reserve(n);
for (int i = 0; i < n; i++) {
int d;
std::cin >> d;
data.push_back(d);
}
num_list copy_1(data);
num_list copy_2(data);
double fft, sft = fft = 0;
{
auto start = std::chrono::high_resolution_clock::now();
algo_01(copy_1);
time_passed(start, fft);
}
{
auto start = std::chrono::high_resolution_clock::now();
algo_02(copy_2);
time_passed(start, sft);
}
{
assert(copy_1 == copy_2);
}
printf(
"algo_01 (%.0f) is %s than algo_02 (%.0f) by %.0f microseconds\n",
fft, (fft > sft? "slower" : "faster"), sft, fabs(fft - sft)
);
}
void algo_01(num_list &cont) { // Stupid sort
auto vit_b = cont.begin() + 1;
while (vit_b != cont.end()) {
auto vit_p = vit_b - 1;
if (*vit_p > *vit_b) {
std::swap(*vit_p, *vit_b);
vit_b = cont.begin() + 1;
}
else {
vit_b += 1;
}
}
}
void algo_02(num_list &cont) { // qSort sort
std::function<int(num_list&, int, int)> choose_mid = [](num_list &cont, int l, int r) {
int v = cont[r];
int pivot = l - 1;
for (int i = l; i <= r - 1; i++) {
if (cont[i] <= v) {
pivot += 1;
std::swap(cont[pivot], cont[i]);
}
}
std::swap(cont[pivot+1], cont[r]);
return pivot + 1;
};
std::function<void(num_list&, int, int)> q_sort = [&choose_mid, &q_sort](num_list &cont, int l, int r) {
if (l < r) {
int mid = choose_mid(cont, l, r);
q_sort(cont, l, mid - 1);
q_sort(cont, mid + 1, r);
}
};
q_sort(cont, 0, cont.size()-1);
}