leetcodeSolution to some Leetcode problems written in C++ |
git clone git://git.dimitrijedobrota.com/leetcode.git |
Log | Files | Refs | README | LICENSE |
1471.cpp (913B)
0 class Solution {
1 public:
2 vector<int> getStrongest(vector<int> &arr, int k) {
3 const int half = (arr.size() - 1) / 2;
4 nth_element(begin(arr), begin(arr) + half, end(arr));
5 const int median = arr[half];
6 nth_element(begin(arr), begin(arr) + k, end(arr), [&](int a, int b) {
7 return abs(a - median) != abs(b - median) ? abs(a - median) > abs(b - median) : a > b;
8 });
9 arr.resize(k);
10 return arr;
11 }
12 };
14 // Two pointer
15 class Solution {
16 public:
17 vector<int> getStrongest(vector<int> &arr, int k) {
18 sort(begin(arr), end(arr));
19 const int median = arr[(arr.size() - 1) / 2];
20 int i = 0, j = arr.size() - 1;
21 while (k--)
22 if (median - arr[i] > arr[j] - median)
23 i++;
24 else
25 j--;
26 arr.erase(begin(arr) + i, begin(arr) + j + 1);
27 return arr;
28 }
29 };