मान लीजिए कि हमारे पास n तत्वों के साथ एक सरणी A है। और तत्वों को क्रमबद्ध किया जाता है। हमें दिए गए पूर्णांक का निकटतम मान ज्ञात करना है। सरणी में डुप्लिकेट मान और ऋणात्मक संख्याएँ हो सकती हैं। तो अगर सरणी [2, 5, 6, 7, 8, 8, 9] की तरह है और लक्ष्य संख्या 4 है, तो निकटतम तत्व 5 है।
हम दिए गए सरणी के माध्यम से इसे हल कर सकते हैं और प्रत्येक तत्व के साथ वर्तमान तत्व के पूर्ण अंतर का ट्रैक रख सकते हैं। अंत में न्यूनतम निरपेक्ष अंतर वाले तत्व को वापस करें।
उदाहरण
#include<iostream> #include<list> using namespace std; int getNearest(int x, int y, int target) { if (target - x >= y - target) return y; else return x; } int getNearestElement(int arr[], int n, int target) { if (target <= arr[0]) return arr[0]; if (target >= arr[n - 1]) return arr[n - 1]; int left = 0, right = n, mid = 0; while (left < right) { mid = (left + right) / 2; if (arr[mid] == target) return arr[mid]; if (target < arr[mid]) { if (mid > 0 && target > arr[mid - 1]) return getNearest(arr[mid - 1], arr[mid], target); right = mid; } else { if (mid < n - 1 && target < arr[mid + 1]) return getNearest(arr[mid], arr[mid + 1], target); left = mid + 1; } } return arr[mid]; } int main() { int arr[] = { 2, 5, 6, 7, 8, 8, 9 }; int n = sizeof(arr) / sizeof(arr[0]); int target = 4; cout << "Nearest element of " << target << " is: " << getNearestElement(arr, n, target); }
आउटपुट
Nearest element of 4 is: 5