मान लीजिए कि हमारे पास कुछ बिंदु हैं, और एक पूर्णांक k है। हमें एक वृत्त की न्यूनतम त्रिज्या ज्ञात करनी है जिसका केंद्र k बिंदुओं को कवर करने के लिए (0, 0) पर है। इसलिए यदि बिंदु (1, 1), (-1, -1), (1, -1), और k =3 जैसे हैं, तो त्रिज्या 2 होगी।
यहां हम प्रत्येक बिंदु और (0, 0) के बीच यूक्लिडियन दूरी पाएंगे, फिर दूरियों को क्रमबद्ध करें और सॉर्ट करने के बाद kth तत्व लौटाएं।
उदाहरण
#include<iostream>
#include<algorithm>
using namespace std;
struct point{
int x, y;
};
int minRadius(int k, point points[], int n) {
int dist[n];
for (int i = 0; i < n; i++)
dist[i] = points[i].x * points[i].x + points[i].y * points[i].y;
// Sorting the distance
sort(dist, dist + n);
return dist[k - 1];
}
int main() {
int k = 3;
point points[] = {{1, 1}, {-1, -1}, {1, -1}};
int n = sizeof(points)/sizeof(points[0]);
cout << "Minimum radius: " << minRadius(k, points, n) << endl;
} आउटपुट
Minimum radius: 2