मान लीजिए कि हमारे पास कुछ बिंदु हैं, और एक पूर्णांक 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