डेटा संरचना - पुनरावर्तन मूल बातें

कुछ कंप्यूटर प्रोग्रामिंग भाषाएं खुद को कॉल करने के लिए एक मॉड्यूल या फ़ंक्शन की अनुमति देती हैं। इस तकनीक को रिकर्सन के रूप में जाना जाता है। पुनरावर्तन में, एक कार्यα या तो सीधे कॉल करता है या फ़ंक्शन को कॉल करता है β बदले में मूल फ़ंक्शन को कॉल करता है α। कार्यक्रमα को पुनरावर्ती कार्य कहा जाता है।

Example - एक समारोह खुद को बुला रहा है।

int function(int value) {
   if(value < 1)
      return;
   function(value - 1);

   printf("%d ",value);   
}

Example - एक फ़ंक्शन जो दूसरे फ़ंक्शन को कॉल करता है जो बदले में इसे फिर से कॉल करता है।

int function1(int value1) {
   if(value1 < 1)
      return;
   function2(value1 - 1);
   printf("%d ",value1);   
}
int function2(int value2) {
   function1(value2);
}

गुण

एक पुनरावर्ती फ़ंक्शन लूप की तरह अनंत जा सकता है। पुनरावर्ती फ़ंक्शन के अनंत भाग से बचने के लिए, दो गुण हैं जो एक पुनरावर्ती फ़ंक्शन के पास होना चाहिए -

  • Base criteria - कम से कम एक आधार मानदंड या शर्त होनी चाहिए, जैसे कि, जब यह शर्त पूरी हो जाती है तो फ़ंक्शन खुद को पुनरावर्ती कॉल करना बंद कर देता है।

  • Progressive approach - पुनरावर्ती कॉल इस तरह से प्रगति करना चाहिए कि हर बार एक पुनरावर्ती कॉल किया जाता है यह आधार मानदंड के करीब आता है।

कार्यान्वयन

कई प्रोग्रामिंग भाषाओं के माध्यम से पुनरावृत्ति को लागू करते हैं stacks। आम तौर पर, जब भी कोई फ़ंक्शन (caller) दूसरे फ़ंक्शन को कॉल करता है (callee) या खुद को केली के रूप में, कॉलर फ़ंक्शन कैली के लिए निष्पादन नियंत्रण स्थानांतरित करता है। इस हस्तांतरण प्रक्रिया में कॉल करने वाले से कैली तक कुछ डेटा शामिल किया जा सकता है।

इसका तात्पर्य है, कॉलर फ़ंक्शन को अस्थायी रूप से इसके निष्पादन को निलंबित करना और बाद में फिर से शुरू करना है जब निष्पादन नियंत्रण कैली फ़ंक्शन से लौटता है। यहां, कॉलर फ़ंक्शन को निष्पादन के बिंदु से बिल्कुल शुरू करने की आवश्यकता है जहां यह खुद को पकड़ में रखता है। इसे उसी सटीक डेटा मान की भी आवश्यकता है जिस पर यह काम कर रहा था। इस प्रयोजन के लिए, कॉलर फ़ंक्शन के लिए एक सक्रियण रिकॉर्ड (या स्टैक फ़्रेम) बनाया जाता है।

यह सक्रियण रिकॉर्ड स्थानीय चर, औपचारिक मापदंडों, वापसी पते और कॉलर फ़ंक्शन को दी गई सभी जानकारी के बारे में जानकारी रखता है।

पुनरावर्तन का विश्लेषण

एक तर्क हो सकता है कि पुनरावृत्ति का उपयोग क्यों करना है, क्योंकि एक ही कार्य पुनरावृत्ति के साथ किया जा सकता है। पहला कारण है, पुनरावृत्ति एक प्रोग्राम को अधिक पठनीय बनाता है और नवीनतम बढ़ाया सीपीयू सिस्टम के कारण पुनरावृत्ति पुनरावृत्तियों की तुलना में अधिक कुशल है।

समय जटिलता

पुनरावृत्तियों के मामले में, हम समय की जटिलता को गिनने के लिए पुनरावृत्तियों की संख्या लेते हैं। इसी तरह, पुनरावृत्ति के मामले में, सब कुछ स्थिर है, हम यह पता लगाने की कोशिश करते हैं कि एक पुनरावर्ती कॉल कितनी बार किया जा रहा है। एक फ़ंक्शन के लिए की गई कॉल Ο (1) है, इसलिए एक पुनरावर्ती कॉल किए जाने की संख्या (n) बार बार पुनरावर्ती फ़ंक्शन rec (n) बनाती है।

अंतरिक्ष जटिलता

अंतरिक्ष की जटिलता को गिना जाता है कि मॉड्यूल को निष्पादित करने के लिए कितनी अतिरिक्त जगह की आवश्यकता होती है। पुनरावृत्तियों के मामले में, कंपाइलर को शायद ही किसी अतिरिक्त स्थान की आवश्यकता होती है। संकलक पुनरावृत्तियों में प्रयुक्त चर के मूल्यों को अद्यतन करता रहता है। लेकिन पुनरावृत्ति के मामले में, सिस्टम को हर बार एक पुनरावर्ती कॉल किए जाने पर सक्रियण रिकॉर्ड को संग्रहीत करने की आवश्यकता होती है। इसलिए, यह माना जाता है कि पुनरावर्ती फ़ंक्शन की अंतरिक्ष जटिलता पुनरावृत्ति वाले फ़ंक्शन की तुलना में अधिक हो सकती है।