-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path2_3.cpp
More file actions
76 lines (65 loc) · 1.8 KB
/
2_3.cpp
File metadata and controls
76 lines (65 loc) · 1.8 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#include "BFPRT.hpp"
#include "pcg_random.hpp" // 非常优秀的现代伪随机生成器
#include <iostream>
#include <random> // 为了在PCG算法中使用C11风格的 random device 安全初始化
#include <vector>
using namespace std;
int
main ()
{
cout.precision (4);
int k = 0, N = 0;
vector<double> arr;
// cin >> k >> N;
// for (int i = 0; i < N; i++)
// {
// int tmp = 0;
// cin >> tmp;
// arr.push_back (tmp);
// }
// generate test data
pcg_extras::seed_seq_from<std::random_device> seed_source;
pcg32 rng (seed_source);
uniform_int_distribution dist (1, 10);
k = 5;
N = 10;
for (int i = 0; i < N; i++)
arr.push_back (dist (rng));
// show input
cout << "median k:" << k << ", total N:" << N << endl;
for (const auto &i : arr)
cout << i << ", ";
cout << endl;
const double lmid = QuickSelect (arr, (arr.size () - 1) / 2);
const double rmid = QuickSelect (arr, arr.size () / 2);
const double mid = (lmid + rmid) / 2;
vector<double> variations;
for (const double &i : arr)
variations.push_back (abs (i - mid));
double maxVar = QuickSelect (variations, k-1);
vector<double> ans, ge;
for (double &i : arr)
{
if (abs (i - mid) < maxVar)
ans.push_back (i);
else
ge.push_back (i);
}
for (double &i : ge) // deal with numbers equal to boundaries
{
if (abs (i - mid) <= maxVar && ans.size () < k)
ans.push_back (i);
}
// cout << endl
// << "lmid:" << lmid << ", rmid:" << rmid << ", median:" << mid << endl;
// cout << "variations:" << endl;
// for (auto &i : variations)
// cout << i << ", ";
// cout << endl;
// cout << "maxVar:" << maxVar << endl;
cout << endl
<< "answer:" << endl;
for (const auto &i : ans)
cout << i << ", ";
cout << endl;
}