बाइनरी खोज एल्गोरिथ्म क्रमबद्ध सूचीमा एक विशेष तत्व खोजी गर्ने एक अधिक प्रभावकारी तरिका हो। रैखिक खोजको विपरीत, जसले तत्वहरूलाई क्रमिक रूपमा जाँच गर्दछ, बाइनरी खोजले सूचीलाई आधा भागहरूमा विभाजन गर्दछ र लक्षित तत्वलाई मध्य तत्वसँग तुलना गर्दछ। लक्ष्य तत्व फेला परेन वा खोज दायरा खाली नभएसम्म यो प्रक्रिया दोहोर्याइएको छ।
यो कसरी काम गर्दछ
- सम्पूर्ण क्रमबद्ध सूची संग सुरु गर्नुहोस्।
- हालको खोज दायराको मध्य तत्व फेला पार्नुहोस्।
- लक्ष्य मानसँग मध्य तत्व तुलना गर्नुहोस्।
- यदि मध्य तत्व लक्ष्य मान बराबर छ, खोज सफल छ।
- यदि बीचको तत्व लक्ष्य भन्दा ठूलो छ भने, दायराको बायाँ आधामा खोज्नुहोस्।
- यदि बीचको तत्व लक्ष्य भन्दा सानो छ भने, दायराको दायाँ आधामा खोज्नुहोस्।
- लक्ष्य तत्व फेला परेन वा खोज दायरा खाली नभएसम्म चरणहरू 2-6 दोहोर्याउनुहोस्।
उदाहरण
पूर्णांकहरूको क्रमबद्ध सूचीलाई विचार गरौं र बाइनरी खोज प्रयोग गरेर नम्बर 34 फेला पार्न चाहन्छौं।
क्रमबद्ध सूची: {12, 23, 34, 45, 56, 67, 89, 90}
- सम्पूर्ण सूचीको साथ सुरू गर्नुहोस्।
- मध्य तत्व: 56(स्थिति 4)। 34 सँग तुलना गर्नुहोस्।
- 56 34 भन्दा ठूलो छ। बायाँ आधामा खोज्नुहोस्।
- नयाँ मध्य तत्व: 23(स्थिति 1)। 34 सँग तुलना गर्नुहोस्।
- 23 34 भन्दा सानो छ। दायाँ हाफमा खोज्नुहोस्।
- नयाँ मध्य तत्व: 45(स्थिति 3)। 34 सँग तुलना गर्नुहोस्।
- 45 34 भन्दा ठूलो छ। बायाँ आधामा खोज्नुहोस्।
- नयाँ मध्य तत्व: 34(स्थिति 2)। लक्ष्य भेटियो।
C++ मा उदाहरण कोड
दिइएको उदाहरणमा, binarySearch
प्रकार्य पूर्णांकहरूको क्रमबद्ध सूचीमा नम्बर 34 फेला पार्न प्रयोग गरिन्छ। नतिजा सूचीमा 34 को स्थिति हुनेछ(पोजिसनहरू 0 बाट सुरु हुन्छ) वा नम्बर फेला परेन भने -1।