डेटा संरचना और एल्गोरिदम बाइनरी सर्च
बाइनरी सर्च search (लॉग एन) की रन-टाइम जटिलता के साथ एक तेज खोज एल्गोरिथ्म है। यह खोज एल्गोरिथ्म विभाजन और जीत के सिद्धांत पर काम करता है। इस एल्गोरिथम को ठीक से काम करने के लिए, डेटा संग्रह क्रमबद्ध रूप में होना चाहिए।
बाइनरी खोज संग्रह के मध्य अधिकांश आइटम की तुलना करके किसी विशेष आइटम की तलाश करती है। यदि एक मैच होता है, तो आइटम का सूचकांक वापस आ जाता है। यदि मध्य आइटम मद से अधिक है, तो आइटम को मध्य आइटम के बाईं ओर उप-सरणी में खोजा जाता है। अन्यथा, आइटम को मध्य आइटम के दाईं ओर उप-सरणी में खोजा जाता है। यह प्रक्रिया उप-सरणी पर भी जारी रहती है, जब तक कि सबर्रे का आकार शून्य तक कम नहीं हो जाता।
बाइनरी सर्च कैसे काम करता है?
काम करने के लिए एक द्विआधारी खोज के लिए, लक्ष्य सरणी को क्रमबद्ध करना अनिवार्य है। हम चित्रात्मक उदाहरण के साथ द्विआधारी खोज की प्रक्रिया सीखेंगे। निम्नलिखित हमारे सॉर्ट किए गए सरणी है और हमें मान लेते हैं कि हमें बाइनरी खोज का उपयोग करके मूल्य 31 का स्थान खोजने की आवश्यकता है।
सबसे पहले, हम इस सूत्र का उपयोग करके सरणी का आधा हिस्सा निर्धारित करेंगे -
mid = low + (high - low) / 2
यहाँ यह है, 0 + (9 - 0) / 2 = 4 (4.5 का पूर्णांक मान)। तो, 4 सरणी के मध्य है।
अब हम स्थान 4 पर संग्रहीत मूल्य की तुलना करते हैं, जिसका मूल्य खोजा जा रहा है, अर्थात 31। हम पाते हैं कि स्थान 4 पर मूल्य 27 है, जो कि मैच नहीं है। चूंकि मान 27 से अधिक है और हमारे पास एक क्रमबद्ध सरणी है, इसलिए हम यह भी जानते हैं कि लक्ष्य मान सरणी के ऊपरी भाग में होना चाहिए।
हम अपने निम्न को मध्य + 1 में बदलते हैं और नए मध्य मान को फिर से पाते हैं।
low = mid + 1
mid = low + (high - low) / 2
हमारा नया मध्य अब now है। हम अपने लक्ष्य मान 31 के साथ स्थान 7 पर संग्रहीत मूल्य की तुलना करते हैं।
स्थान 7 पर संग्रहीत मूल्य एक मैच नहीं है, बल्कि यह उस चीज से अधिक है जो हम खोज रहे हैं। तो, मान इस स्थान से निचले हिस्से में होना चाहिए।
इसलिए, हम फिर से मध्य की गणना करते हैं। इस समय यह 5 है।
हम अपने लक्ष्य मान के साथ स्थान 5 पर संग्रहीत मूल्य की तुलना करते हैं। हम पाते हैं कि यह एक मैच है।
हम यह निष्कर्ष निकालते हैं कि लक्ष्य 5 को स्थान 5 पर संग्रहीत किया गया है।
द्विआधारी खोज खोज योग्य वस्तुओं को आधा कर देती है और इस प्रकार तुलना की संख्या को बहुत कम संख्या में बना देती है।
स्यूडोकोड
द्विआधारी खोज एल्गोरिदम के छद्मकोड को इस तरह देखना चाहिए -
Procedure binary_search
A ← sorted array
n ← size of array
x ← value to be searched
Set lowerBound = 1
Set upperBound = n
while x not found
if upperBound < lowerBound
EXIT: x does not exists.
set midPoint = lowerBound + ( upperBound - lowerBound ) / 2
if A[midPoint] < x
set lowerBound = midPoint + 1
if A[midPoint] > x
set upperBound = midPoint - 1
if A[midPoint] = x
EXIT: x found at location midPoint
end while
end procedure
सी प्रोग्रामिंग भाषा में सरणी का उपयोग करके द्विआधारी खोज कार्यान्वयन के बारे में जानने के लिए, कृपया यहां क्लिक करें ।