मुझे पता है कि एक पूंछ रिकर्सिव एल्गोरिदम written out in this SO answer के रूप में क्या है। हालांकि मैं इस video of quick sort algorithm from MIT और 18:30 सेकंड में जा रहा हूं, प्रोफेसर का कहना है कि यह पूंछ रिकर्सिव एल्गोरिदम है। मैं कनेक्ट करने में असफल रहा कि यह कैसे पूंछ रिकर्सिव है। हम रिकर्सन के किसी भी चरण में गणना नहीं कर रहे हैं या हम हैं? क्या आप समझा सकते हैं कि इसे पूंछ रिकर्सिव एल्गोरिदम के उदाहरण के रूप में क्यों उद्धृत किया गया है। कृपया आधार पर अपना उत्तर आधार दें कि मुझे पता है कि एक रिकर्सिव एल्गोरिदम क्या है। वह हिस्सा जो मुझे स्पष्ट नहीं है, उसे पूंछ रिकर्सिव क्यों कहा जाता है?त्वरित प्रकार को पूंछ रिकर्सिव एल्गोरिदम क्यों कहा जाता है?
उत्तर
रिकर्सिव फ़ंक्शन का पहला चरण विभाजन है। और फिर, अंतिम चरण के रूप में, आप दो विभाजनों पर रिकर्सिव फ़ंक्शन को कॉल करते हैं।
विकिपीडिया से:
कंप्यूटर विज्ञान में, एक पूंछ कॉल एक सबरूटीन कॉल कि अपनी अंतिम कार्रवाई के रूप में एक और प्रक्रिया के अंदर होता है; यह वैल्यू का उत्पादन कर सकता है जिसे तुरंत कॉलिंग प्रक्रिया द्वारा वापस कर दिया जाता है।
पूंछ रिकर्सन चरणों में गणना करने के बारे में नहीं है। यह "कॉल स्टैक के निर्माण के बिना रिकर्सन का मूल्यांकन किया जा सकता है।" What is tail recursion? द्वारा दिया गया उदाहरण यह एक विशेष मामला है। आप और अधिक गहराई से उदाहरण देखें, तो क्या आप पा सकते हैं कि
def recsum(x):
if x==1:
return x
else:
return x+recsum(x-1)
1) उपरोक्त कोड को सफलतापूर्वक चलाने के लिए, आप कॉल स्टैक का निर्माण करने की जरूरत है। लेकिन,
def tailrecsum(x,running_total=0):
if x==0:
return running_total
else:
return tailrecsum(x-1,running_total+x)
2) उपरोक्त कोड को चलाने के लिए, आप running_total की वजह से कॉल स्टैक का निर्माण करने की जरूरत नहीं है। बस "मूल कॉल" के लिए कॉल स्टैक बनाएं और रिकर्सन के लिए, कॉल स्टैक बनाने की कोई आवश्यकता नहीं है, क्योंकि इस फ़ंक्शन का मूल्यांकन करने के लिए आवश्यक स्थिति run_total में संग्रहीत है।
और, त्वरित प्रकार के बारे में, मुझे लगता है कि प्रोफेसर का शायद यह अर्थ था कि त्वरित-प्रकार को पूंछ-भर्ती "उपयोग" द्वारा अनुकूलित किया जा सकता है। Qsort() के दो शाखाओं के हिस्सों के लिए, हम एक तरफ पूंछ-पुनरावर्तन का उपयोग कर सकते हैं जिसमें उच्च वस्तुएं हैं (पिवट स्थिति के आधार पर)।
क्या आप इसे आगे बताने के लिए अपने उत्तर में कॉल स्टैक डाल सकते हैं। मेरे लिए ऐसा लगता है कि आपको दोनों प्रक्रियाओं में कॉल स्टैक बनाने की आवश्यकता है। tailrecsum पूंछ रिकर्सिव कॉल कॉल tailrecsum कहते हैं .... तो कॉल ढेर का निर्माण हो रहा है ... क्या यह नहीं है? – Geek
यह मेरी पिछली टिप्पणी से निरंतरता है ... संकलक स्टैक के निर्माण के बिना एक रिकर्सिव कॉल की गणना कैसे कर सकता है? "कॉल स्टैक बनाने" से आपका क्या मतलब है? – Geek
@ गीक: मैं इस विषय में सिर्फ एक नौसिखिया हूं, और मैं "कंप्यूटर प्रोग्राम की संरचना और व्याख्या" (एसआईसीपी) पढ़ने की प्रक्रिया में हूं, जो मुफ्त ऑनलाइन उपलब्ध है; पूंछ-पुनरावर्तन की अवधारणा विषय "रैखिक रिकर्सन बनाम पुनरावृत्ति" विषय से घनिष्ठ रूप से संबंधित है। एसआईसीपी के बारे में यहां बहुत कुछ कहना है: http://mitpress.mit.edu/sicp/full-text/book/book-Z-H-11.html#%_sec_1.2.1। एसआईसीपी से यह लिंक यह स्पष्ट रूप से बताता है। – favq
Quicksort की विकि पृष्ठ पर एक नजर डालें। पुनरावर्ती
function quicksort(array, 'left', 'right')
// If the list has 2 or more items
if 'left' < 'right'
// See "Choice of pivot" section below for possible choices
choose any 'pivotIndex' such that 'left' ≤ 'pivotIndex' ≤ 'right'
// Get lists of bigger and smaller items and final position of pivot
'pivotNewIndex' := partition(array, 'left', 'right', 'pivotIndex')
// Recursively sort elements smaller than the pivot
quicksort(array, 'left', 'pivotNewIndex' - 1)
// Recursively sort elements at least as big as the pivot
quicksort(array, 'pivotNewIndex' + 1, 'right')
Tail recursion की परिभाषा के अनुसार पूंछ का एक संस्करण है, quicksort
के अंतिम विधि कॉल ही है कि पूंछ प्रत्यावर्तन है,। लेकिन कुछ अन्य कार्यान्वयन पूंछ रिकर्सिव नहीं हैं।
quicksort(left) + pivot + quicksort(right)
क्योंकि quicksort
में अंतिम कार्रवाई है sorted_left + pivot + sorted_right
है कि अपने पिछले प्रश्न से विकिपीडिया लेख
क्या अन्य इसकी सटीकता की पुष्टि कर सकते हैं? –
आप पढ़ सकते हैं किया था? – Andrey
@ एंड्रे हां मैंने किया लेकिन मुझे एसओ में जवाब मिला कि मैंने समझने के लिए आसान और स्पष्ट होने के लिए जोड़ा है। – Geek
संभावित डुप्लिकेट [पूंछ-रिकर्सन क्या है?] (Http://stackoverflow.com/questions/33923/what-is-tail-recursion)। एक बार जब आप पूंछ रिकर्सिव की परिभाषा देखते हैं, तो 17:28 पर एल्गोरिदम की परिभाषा, यह स्पष्ट है कि यह पूंछ रिकर्सिव है, क्योंकि रिकर्सिव चरण का वापसी मूल्य स्वयं को कॉल का वापसी मूल्य है। –