एरलंग - पुनरावृत्ति

पुनरावृत्ति एर्लांग का एक महत्वपूर्ण हिस्सा है। पहले देखते हैं कि हम फैक्टोरियल प्रोग्राम को लागू करके सरल पुनरावृत्ति कैसे कर सकते हैं।

उदाहरण

-module(helloworld). 
-export([fac/1,start/0]). 

fac(N) when N == 0 -> 1; 
fac(N) when N > 0 -> N*fac(N-1). 

start() -> 
   X = fac(4), 
   io:fwrite("~w",[X]).

उपरोक्त कार्यक्रम के बारे में निम्नलिखित बातों पर ध्यान देने की आवश्यकता है -

  • हम पहले फंक्शन (एन) नामक एक फ़ंक्शन को परिभाषित कर रहे हैं।

  • हम पुनरावर्ती फ़ंक्शन को फोन (N) को पुनरावर्ती रूप से परिभाषित करने में सक्षम हैं।

उपरोक्त कार्यक्रम का आउटपुट है -

उत्पादन

24

पुनरावर्तन के लिए व्यावहारिक दृष्टिकोण

इस खंड में, हम विभिन्न प्रकार की पुनरावृत्तियों और इसके उपयोग के बारे में एर्लांग में विस्तार से समझेंगे।

लंबाई पुनरावृत्ति

पुनरावृत्ति के लिए एक अधिक व्यावहारिक दृष्टिकोण एक सरल उदाहरण के साथ देखा जा सकता है जो किसी सूची की लंबाई निर्धारित करने के लिए उपयोग किया जाता है। एक सूची में कई मूल्य हो सकते हैं जैसे कि [1,2,3,4]। आइए हम यह देखने के लिए पुनरावर्तन का उपयोग करें कि हम किसी सूची की लंबाई कैसे प्राप्त कर सकते हैं।

Example

-module(helloworld). 
-export([len/1,start/0]). 

len([]) -> 0; 
len([_|T]) -> 1 + len(T). 

start() -> 
   X = [1,2,3,4], 
   Y = len(X), 
   io:fwrite("~w",[Y]).

उपरोक्त कार्यक्रम के बारे में निम्नलिखित बातों पर ध्यान देने की आवश्यकता है -

  • पहला समारोह len([]) सूची खाली होने पर विशेष स्थिति स्थिति के लिए उपयोग किया जाता है।

  • [H|T] एक या एक से अधिक तत्वों की सूची से मिलान करने के लिए पैटर्न, लंबाई की सूची के रूप में परिभाषित किया जाएगा [X|[]] और लंबाई दो की एक सूची के रूप में परिभाषित किया जाएगा [X|[Y|[]]]। ध्यान दें कि दूसरा तत्व एक सूची है। इसका मतलब है कि हमें केवल पहले एक को गिनना होगा और फ़ंक्शन दूसरे तत्व पर कॉल कर सकता है। सूची में प्रत्येक मान को 1 की लंबाई के रूप में गिना जाता है।

उपरोक्त कार्यक्रम का उत्पादन होगा -

Output

4

पूंछ पुनरावृत्ति

यह समझने के लिए कि पूंछ पुनरावृत्ति कैसे काम करती है, आइए समझते हैं कि पिछले अनुभाग में निम्नलिखित कोड कैसे काम करता है।

Syntax

len([]) -> 0; 
len([_|T]) -> 1 + len(T).

1 + len (रेस्ट) के उत्तर को len (रेस्ट) के उत्तर की आवश्यकता है। फंक्शन लेन (रेस्ट) के बाद ही दूसरे फंक्शन कॉल के परिणाम की जरूरत पड़ी। पिछले एक के मिलने तक अतिरिक्त जुड़ जाएगा, और उसके बाद ही अंतिम परिणाम की गणना की जाएगी।

पूंछ पुनरावृत्ति का उद्देश्य ऑपरेशन के इस स्टैकिंग को समाप्त करना है, जैसा कि वे होते हैं।

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

आइए पूंछ के पुनरावर्तन का एक उदाहरण देखें -

Example

-module(helloworld).
-export([tail_len/1,tail_len/2,start/0]). 

tail_len(L) -> tail_len(L,0). 
tail_len([], Acc) -> Acc; 
tail_len([_|T], Acc) -> tail_len(T,Acc+1). 

start() -> 
   X = [1,2,3,4], 
   Y = tail_len(X), 
   io:fwrite("~w",[Y]).

उपरोक्त कार्यक्रम का आउटपुट है -

Output

4

डुप्लिकेट

आइए एक नजर डालते हैं रिकर्सन के उदाहरण पर। इस बार के आसपास एक फ़ंक्शन लिखें जो पूर्णांक को इसके पहले पैरामीटर के रूप में लेता है और फिर किसी दूसरे शब्द को इसके दूसरे पैरामीटर के रूप में लेता है। यह तब पूर्णांक द्वारा निर्दिष्ट शब्द की कई प्रतियों की एक सूची बनाएगा।

आइए देखें कि इसका एक उदाहरण कैसा दिखेगा -

-module(helloworld). 
-export([duplicate/2,start/0]). 

duplicate(0,_) -> 
   []; 
duplicate(N,Term) when N > 0 ->
   io:fwrite("~w,~n",[Term]),
   [Term|duplicate(N-1,Term)]. 
start() -> 
   duplicate(5,1).

उपरोक्त कार्यक्रम का उत्पादन होगा -

उत्पादन

1,
1,
1,
1,
1,

सूची का उलटा

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

उदाहरण

-module(helloworld). 
-export([tail_reverse/2,start/0]). 

tail_reverse(L) -> tail_reverse(L,[]).

tail_reverse([],Acc) -> Acc; 
tail_reverse([H|T],Acc) -> tail_reverse(T, [H|Acc]).

start() -> 
   X = [1,2,3,4], 
   Y = tail_reverse(X), 
   io:fwrite("~w",[Y]).

उपरोक्त कार्यक्रम का उत्पादन होगा -

उत्पादन

[4,3,2,1]

उपरोक्त कार्यक्रम के बारे में निम्नलिखित बातों पर ध्यान देने की आवश्यकता है -

  • हम फिर से Acc नामक एक चर में सूची के प्रत्येक तत्व को संग्रहीत करने के लिए अस्थायी चर की अवधारणा का उपयोग कर रहे हैं।

  • हम फिर फोन करते हैं tail_reverse पुनरावर्ती रूप से, लेकिन इस बार के आसपास, हम यह सुनिश्चित करते हैं कि अंतिम तत्व को नई सूची में पहले रखा जाए।

  • फिर हम सूची में प्रत्येक तत्व के लिए tail_reverse को पुन: कॉल करते हैं।