สมมติว่าเรามีอาร์เรย์ของตัวเลขที่เรียกว่า arr และจำนวนเต็ม k มีค่า arr[i] ที่กล่าวว่าแข็งแกร่งกว่าค่า arr[j] เมื่อ |arr[i] - m|> |arr[j] - m| โดยที่ m คือค่ามัธยฐานของอาร์เรย์ ถ้า |arr[i] - m| เหมือนกับ |arr[j] - m| ดังนั้น arr[i] จะถูกกล่าวว่าแข็งแกร่งกว่า arr[j] ถ้า arr[i]> arr[j] ดังนั้นเราจึงต้องหารายการค่า k ที่แรงที่สุดในอาร์เรย์
ดังนั้น หากอินพุตมีค่าเท่ากับ arr =[1,2,3,4,5], k =2 ผลลัพธ์จะเป็น [5,1] เนื่องจากค่ามัธยฐานคือ 3 และจัดเรียงองค์ประกอบของอาร์เรย์ โดยที่แข็งแกร่งที่สุดคือ [5,1,4,2,3] องค์ประกอบ 2 อย่างที่แข็งแกร่งที่สุดคือ [5, 1] [1, 5] ก็ใช้ได้เช่นกัน แม้ว่า |5 - 3| เหมือนกับ |1 - 3| แต่ 5 แรงกว่า 1 เพราะ 5> 1.
เพื่อแก้ปัญหานี้ เราจะทำตามขั้นตอนเหล่านี้ -
-
จัดเรียงอาร์เรย์ arr
-
n :=ขนาดของ arr
-
m :=arr[(n - 1)/2]
-
กำหนดอาร์เรย์ v ของคู่
-
ผม :=0, j :=n - 1
-
กำหนดอาร์เรย์ ret
-
ในขณะที่ k ไม่ใช่ศูนย์ ให้ลด k ในการวนซ้ำแต่ละครั้ง ทำ -
-
x1 :=|arr[j]- m|
-
x2 :=|arr[i]- m|
-
ถ้า x1>=x2 แล้ว −
-
ใส่ arr[j] ต่อท้าย ret
-
(ลด j โดย 1)
-
-
มิฉะนั้น
-
ใส่ arr[i] ต่อท้าย ret
-
(เพิ่ม i ขึ้น 1)
-
-
-
รีเทิร์น
ตัวอย่าง
ให้เราดูการใช้งานต่อไปนี้เพื่อความเข้าใจที่ดีขึ้น -
#include <bits/stdc++.h> using namespace std; void print_vector(vector<int> v){ cout << "["; for(int i = 0; i<v.size(); i++){ cout << v[i] << ", "; } cout << "]"<<endl; } class Solution { public: int calc(int x, int m){ return abs(x - m); } vector<int> getStrongest(vector<int>& arr, int k) { sort(arr.begin(), arr.end()); int n = arr.size(); int m = arr[(n - 1) / 2]; vector<pair<int, int> > v; int i = 0; int j = n - 1; vector<int> ret; while (k--) { int x1 = calc(arr[j], m); int x2 = calc(arr[i], m); if (x1 >= x2) { ret.push_back(arr[j]); j--; } else { ret.push_back(arr[i]); i++; } } return ret; } }; main(){ Solution ob; vector<int> v = {1,2,3,4,5}; print_vector(ob.getStrongest(v,2)); }
อินพุต
{1,2,3,4,5},2
ผลลัพธ์
[5, 1, ]