डेटा संरचना और एल्गोरिदम - हनोई का टॉवर
हनोई का टॉवर, एक गणितीय पहेली है जिसमें तीन टावरों (खूंटे) होते हैं और एक से अधिक छल्ले को दर्शाया गया है -
ये छल्ले अलग-अलग आकार के होते हैं और आरोही क्रम में स्टैक्ड होते हैं, अर्थात छोटा बड़ा के ऊपर बैठता है। पहेली की अन्य विविधताएँ हैं जहाँ डिस्क की संख्या में वृद्धि होती है, लेकिन टॉवर की गिनती समान रहती है।
नियम
मिशन व्यवस्था के अनुक्रम का उल्लंघन किए बिना सभी डिस्क को किसी अन्य टॉवर में स्थानांतरित करना है। हनोई के टॉवर के लिए किए जाने वाले कुछ नियम हैं -
- किसी भी समय केवल एक डिस्क को टावरों के बीच ले जाया जा सकता है।
- केवल "शीर्ष" डिस्क को हटाया जा सकता है।
- छोटी डिस्क पर कोई बड़ी डिस्क नहीं बैठ सकती है।
निम्नलिखित तीन डिस्क के साथ हनोई पहेली के टॉवर को हल करने का एक एनिमेटेड प्रतिनिधित्व है।
एन डिस्क के साथ हनोई पहेली का टॉवर न्यूनतम में हल किया जा सकता है 2n−1कदम। इस प्रस्तुति से पता चलता है कि 3 डिस्क के साथ एक पहेली ली गई है23 - 1 = 7 कदम।
कलन विधि
हनोई के टॉवर के लिए एक एल्गोरिथ्म लिखने के लिए, पहले हमें यह जानने की जरूरत है कि डिस्क की कम मात्रा के साथ इस समस्या को कैसे हल किया जाए, → → 1 या 2. हम नाम के साथ तीन टावरों को चिह्नित करते हैं, source, destination तथा aux(केवल डिस्क को स्थानांतरित करने में मदद करने के लिए)। यदि हमारे पास केवल एक डिस्क है, तो इसे आसानी से स्रोत से गंतव्य खूंटी में स्थानांतरित किया जा सकता है।
अगर हमारे पास 2 डिस्क हैं -
- सबसे पहले, हम छोटी (शीर्ष) डिस्क को ऑक्स पेग में स्थानांतरित करते हैं।
- उसके बाद, हम बड़े (नीचे) डिस्क को गंतव्य खूंटी पर ले जाते हैं।
- और अंत में, हम छोटी डिस्क को ऐक्स से गंतव्य खूंटी में स्थानांतरित करते हैं।
इसलिए अब, हम दो से अधिक डिस्क के साथ हनोई के टॉवर के लिए एक एल्गोरिथ्म डिजाइन करने की स्थिति में हैं। हम डिस्क के ढेर को दो भागों में विभाजित करते हैं। सबसे बड़ी डिस्क (n th डिस्क) एक भाग में है और अन्य सभी (n-1) डिस्क दूसरे भाग में हैं।
हमारा अंतिम उद्देश्य डिस्क को स्थानांतरित करना है nस्रोत से गंतव्य तक और फिर उस पर अन्य सभी (n1) डिस्क डालें। हम डिस्क के सभी सेट के लिए पुनरावर्ती तरीके से समान लागू करने की कल्पना कर सकते हैं।
अनुसरण करने के चरण हैं -
Step 1 − Move n-1 disks from source
to aux
Step 2 − Move nth disk from source
to dest
Step 3 − Move n-1 disks from aux
to dest
हनोई के टॉवर के लिए एक पुनरावर्ती एल्गोरिदम निम्नानुसार संचालित किया जा सकता है -
START
Procedure Hanoi(disk, source, dest, aux)
IF disk == 1, THEN
move disk from source to dest
ELSE
Hanoi(disk - 1, source, aux, dest) // Step 1
move disk from source to dest // Step 2
Hanoi(disk - 1, aux, dest, source) // Step 3
END IF
END Procedure
STOP
सी प्रोग्रामिंग में कार्यान्वयन की जांच करने के लिए, यहां क्लिक करें ।