एरलंग - पुनरावृत्ति
पुनरावृत्ति एर्लांग का एक महत्वपूर्ण हिस्सा है। पहले देखते हैं कि हम फैक्टोरियल प्रोग्राम को लागू करके सरल पुनरावृत्ति कैसे कर सकते हैं।
उदाहरण
-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 को पुन: कॉल करते हैं।