समानांतर खोज एल्गोरिथम

खोज कंप्यूटर विज्ञान के मूलभूत कार्यों में से एक है। इसका उपयोग उन सभी अनुप्रयोगों में किया जाता है जहां हमें यह पता लगाने की आवश्यकता होती है कि कोई तत्व दी गई सूची में है या नहीं। इस अध्याय में, हम निम्नलिखित खोज एल्गोरिदम पर चर्चा करेंगे -

  • विभाजन और जीत
  • गहराई-पहली खोज
  • पहले चौड़ाई खोजो
  • बेस्ट-फर्स्ट सर्च

विभाजन और जीत

विभाजित और जीत के दृष्टिकोण में, समस्या को कई छोटी उप-समस्याओं में विभाजित किया गया है। तब उप-समस्याओं को मूल समस्या का समाधान प्राप्त करने के लिए पुनरावर्ती और संयुक्त रूप से हल किया जाता है।

फूट डालो और जीतो दृष्टिकोण में प्रत्येक स्तर पर निम्नलिखित चरण शामिल हैं -

  • Divide - मूल समस्या को उप-समस्याओं में विभाजित किया गया है।

  • Conquer - उप-समस्याओं को पुनरावर्ती रूप से हल किया जाता है।

  • Combine - मूल समस्याओं के समाधान के लिए उप-समस्याओं के समाधान को मिलाया जाता है।

बाइनरी खोज डिवाइड को विभाजित करने और जीतने का एक उदाहरण है।

स्यूडोकोड

Binarysearch(a, b, low, high)

if low < high then
   return NOT FOUND
else
   mid ← (low+high) / 2
   if b = key(mid) then
      return key(mid)
   else if b < key(mid) then
      return BinarySearch(a, b, low, mid−1)
   else
   
      return BinarySearch(a, b, mid+1, high)

गहराई-पहली खोज

गहराई-पहली खोज (या डीएफएस) एक पेड़ या एक अप्रत्यक्ष ग्राफ़ डेटा संरचना की खोज के लिए एक एल्गोरिथ्म है। यहाँ, अवधारणा को शुरुआती नोड से शुरू करना है जिसे के रूप में जाना जाता हैrootऔर जहां तक ​​संभव हो एक ही शाखा में यात्रा करें। यदि हमें कोई उत्तराधिकारी नोड के साथ एक नोड मिलता है, तो हम वापस लौटते हैं और शीर्ष के साथ जारी रखते हैं, जिसे अभी तक जाना है।

गहराई-पहली खोज के चरण

  • एक नोड (मूल) पर विचार करें जो पहले का दौरा नहीं किया गया है और इसे दौरा किया गया है।

  • पहले आसन्न उत्तराधिकारी नोड पर जाएं और इसे चिह्नित करें।

  • यदि माना गया नोड के सभी उत्तराधिकारी नोड पहले से ही आ चुके हैं या उसके पास कोई भी अधिक उत्तराधिकारी नोड नहीं है, तो अपने मूल नोड पर वापस लौटें।

स्यूडोकोड

लश्कर v वह स्थान हो जहां खोज ग्राफ़ में शुरू होती है G

DFS(G,v)

   Stack S := {};
	
   for each vertex u, set visited[u] := false;
   push S, v;
   while (S is not empty) do
     u := pop S;
	  
      if (not visited[u]) then
         visited[u] := true;
         for each unvisited neighbour w of u
            push S, w;
      end if
		
   end while
   
END DFS()

पहले चौड़ाई खोजो

चौड़ाई-पहली खोज (या BFS) एक पेड़ या एक अप्रत्यक्ष ग्राफ़ डेटा संरचना की खोज के लिए एक एल्गोरिथ्म है। यहां, हम एक नोड के साथ शुरू करते हैं और फिर उसी स्तर के सभी आसन्न नोड्स पर जाते हैं और फिर अगले स्तर पर आसन्न उत्तराधिकारी नोड पर जाते हैं। इस रूप में भी जाना जाता हैlevel-by-level search

चौड़ाई-प्रथम खोज के चरण

  • रूट नोड के साथ शुरू करें, इसे चिह्नित करें।
  • जैसा कि रूट नोड में समान स्तर में कोई नोड नहीं है, अगले स्तर पर जाएं।
  • सभी आसन्न नोड्स पर जाएँ और उन्हें चिन्हित करें।
  • अगले स्तर पर जाएं और सभी असंगत आसन्न नोड्स पर जाएं।
  • इस प्रक्रिया को तब तक जारी रखें जब तक कि सभी नोड्स का दौरा न हो जाए।

स्यूडोकोड

लश्कर v वह स्थान हो जहां खोज ग्राफ़ में शुरू होती है G

BFS(G,v)

   Queue Q := {};
	
   for each vertex u, set visited[u] := false;
   insert Q, v;
   while (Q is not empty) do
      u := delete Q;
		
      if (not visited[u]) then
         visited[u] := true;
         for each unvisited neighbor w of u
            insert Q, w;
      end if
		
   end while
   
END BFS()

बेस्ट-फर्स्ट सर्च

बेस्ट-फर्स्ट सर्च एक एल्गोरिथ्म है जो कम से कम संभव पथ में लक्ष्य तक पहुंचने के लिए एक ग्राफ को पीछे छोड़ता है। बीएफएस और डीएफएस के विपरीत, बेस्ट-फर्स्ट सर्च एक मूल्यांकन फ़ंक्शन का अनुसरण करता है, यह निर्धारित करने के लिए कि कौन सा नोड अगले पार करने के लिए सबसे उपयुक्त है।

सर्वश्रेष्ठ-प्रथम खोज के चरण

  • रूट नोड के साथ शुरू करें, इसे चिह्नित करें।
  • अगले उपयुक्त नोड का पता लगाएं और इसे चिह्नित करें।
  • अगले स्तर पर जाएं और उपयुक्त नोड को ढूंढें और इसे चिह्नित करें।
  • इस प्रक्रिया को तब तक जारी रखें जब तक कि लक्ष्य पूरा न हो जाए।

स्यूडोकोड

BFS( m )

   Insert( m.StartNode )
   Until PriorityQueue is empty
      c ← PriorityQueue.DeleteMin
      If c is the goal
      Exit
   Else
   
      Foreach neighbor n of c
         If n "Unvisited"
            Mark n "Visited"
            Insert( n )
      Mark c "Examined"
      
End procedure