अमृत ​​- पुनरावृत्ति

रिकर्सियन एक ऐसी विधि है जहां किसी समस्या का समाधान उसी समस्या के छोटे उदाहरणों के समाधान पर निर्भर करता है। अधिकांश कंप्यूटर प्रोग्रामिंग भाषाएं फ़ंक्शन को प्रोग्राम टेक्स्ट के भीतर कॉल करने की अनुमति देकर पुनरावृत्ति का समर्थन करती हैं।

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

defmodule Math do
   def fact(res, num) do
   if num === 1 do
      res
   else
      new_res = res * num
      fact(new_res, num-1)
      end
   end
end

IO.puts(Math.fact(1,5))

जब उपरोक्त कार्यक्रम चलाया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

120

इसलिए उपरोक्त कार्य में, Math.fact, हम एक संख्या के भाज्य की गणना कर रहे हैं। ध्यान दें कि हम फ़ंक्शन को अपने भीतर बुला रहे हैं। आइए अब समझते हैं कि यह कैसे काम करता है।

हमने इसे 1 और उस संख्या के साथ प्रदान किया है जिसकी गुत्थी हम गणना करना चाहते हैं। फ़ंक्शन यह जांचता है कि संख्या 1 है या नहीं और यदि यह 1 है तो रिटर्न फिर से शुरू होता है(Ending condition)। यदि नहीं, तो यह एक वैरिएबल new_res बनाता है और इसे पिछले res * current num का मान प्रदान करता है। यह हमारे फ़ंक्शन कॉल तथ्य (new_res, num-1) द्वारा लौटाया गया मान लौटाता है । यह दोहराता है जब तक कि हम संख्या 1 प्राप्त नहीं करते हैं। एक बार ऐसा होने पर, हमें परिणाम मिलता है।

आइए एक और उदाहरण पर विचार करें, सूची के प्रत्येक तत्व को एक-एक करके प्रिंट करना। ऐसा करने के लिए, हम इसका उपयोग करेंगेhd तथा tl कार्यों में सूचियों और पैटर्न के मिलान के कार्य -

a = ["Hey", 100, 452, :true, "People"]
defmodule ListPrint do
   def print([]) do
   end
   def print([head | tail]) do 
      IO.puts(head)
      print(tail)
   end
end

ListPrint.print(a)

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

Hey
100
452
true
People