डेटा संरचना - गहराई पहले ट्रैवर्सल
डेप्थ फर्स्ट सर्च (डीएफएस) एल्गोरिथ्म एक ग्राफ को गहराई से गति करता है और एक खोज शुरू करने के लिए अगला शीर्ष प्राप्त करने के लिए याद रखने के लिए एक स्टैक का उपयोग करता है, जब किसी भी पुनरावृत्ति में एक मृत अंत होता है।
जैसा कि ऊपर दिए गए उदाहरण में बताया गया है, DFS एल्गोरिथ्म S से A से D तक G से E से B पहले, फिर F से और अंत में C. से पता चलता है। यह निम्नलिखित नियमों को नियोजित करता है।
Rule 1- समीपवर्ती अप्रकाशित शिखर पर जाएँ। इसे चिह्नित के रूप में चिह्नित करें। इसे प्रदर्शित करें। इसे ढेर में दबा दें।
Rule 2- यदि कोई निकटवर्ती शीर्ष नहीं पाया जाता है, तो स्टैक से एक शीर्ष को पॉप करें। (यह स्टैक से सभी कोने को पॉप अप करेगा, जिसमें आसन्न कोने नहीं हैं।)
Rule 3 - स्टैक खाली होने तक नियम 1 और नियम 2 को दोहराएं।
कदम | traversal | विवरण |
---|---|---|
1 |
|
स्टैक को प्रारंभ करें। |
2 |
|
निशान Sके रूप में दौरा किया और यह ढेर पर डाल दिया। किसी भी गैर-समीपवर्ती नोड का अन्वेषण करेंS। हमारे पास तीन नोड हैं और हम उनमें से किसी को भी चुन सकते हैं। इस उदाहरण के लिए, हम नोड को एक वर्णमाला क्रम में लेंगे। |
3 |
|
निशान Aके रूप में दौरा किया और यह ढेर पर डाल दिया। ए। दोनों से किसी भी गैर-समीपवर्ती नोड का अन्वेषण करेंS तथा D से सटे हुए हैं A लेकिन हम केवल गैर-अधिकृत नोड्स के लिए चिंतित हैं। |
4 |
|
यात्रा Dऔर उस पर जाएँ और स्टैक पर रखें। हमारे पास हैB तथा C नोड्स, जो आसन्न हैं Dऔर दोनों की परिकल्पना नहीं की गई है। हालाँकि, हम फिर से एक वर्णमाला क्रम में चयन करेंगे। |
5 |
|
हम चुनेंगे Bके रूप में यह दौरा किया और ढेर पर डाल दिया। यहाँBकिसी भी गैर-समीपवर्ती नोड के पास नहीं है। तो, हम पॉपB ढेर से। |
6 |
|
हम पिछले नोड पर लौटने के लिए स्टैक शीर्ष की जांच करते हैं और जांचते हैं कि क्या यह किसी भी गैर-नोड नोड्स में है। यहाँ, हम पाते हैंD ढेर के शीर्ष पर होना। |
7 |
|
केवल अप्रयुक्त आसन्न नोड से है D है Cअभी। इसलिए हम यात्रा करते हैंCके रूप में चिह्नित पर जाएँ और इसे स्टैक पर रखें। |
जैसा Cहमारे पास किसी भी तरह के गैर-समीपवर्ती नोड नहीं है, इसलिए हम स्टैक को तब तक पॉपअप करते रहते हैं जब तक कि हमें एक नोड न मिल जाए जो कि आसन्न नोड है। इस स्थिति में, कोई भी नहीं है और हम तब तक पॉपिंग करते रहते हैं जब तक कि स्टैक खाली न हो जाए।
सी प्रोग्रामिंग भाषा में इस एल्गोरिथ्म के कार्यान्वयन के बारे में जानने के लिए, यहां क्लिक करें ।