गो - पुनरावृत्ति

पुनरावृत्ति एक स्व-समान तरीके से वस्तुओं को दोहराने की प्रक्रिया है। प्रोग्रामिंग भाषाओं में भी यही अवधारणा लागू होती है। यदि कोई प्रोग्राम समान फ़ंक्शन के अंदर किसी फ़ंक्शन को कॉल करने की अनुमति देता है, तो उसे पुनरावर्ती फ़ंक्शन कॉल कहा जाता है। निम्नलिखित उदाहरण पर एक नज़र डालें -

func recursion() {
   recursion() /* function calls itself */
}
func main() {
   recursion()
}

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

गो में पुनरावृत्ति के उदाहरण

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

उदाहरण 1: गो में रिकर्सियन का उपयोग करके फैक्टरियल की गणना

निम्न उदाहरण एक पुनरावर्ती फ़ंक्शन का उपयोग करके किसी दिए गए संख्या के भाज्य की गणना करता है -

package main

import "fmt"

func factorial(i int)int {
   if(i <= 1) {
      return 1
   }
   return i * factorial(i - 1)
}
func main() { 
   var i int = 15
   fmt.Printf("Factorial of %d is %d", i, factorial(i))
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

Factorial of 15 is 1307674368000

उदाहरण 2: गो में पुनरावृत्ति का उपयोग करते हुए फाइबोनैचि श्रृंखला

निम्न उदाहरण दिखाता है कि किसी पुनरावर्ती फ़ंक्शन का उपयोग करके किसी दिए गए नंबर की फाइबोनैचि श्रृंखला कैसे बनाई जाए -

package main

import "fmt"

func fibonaci(i int) (ret int) {
   if i == 0 {
      return 0
   }
   if i == 1 {
      return 1
   }
   return fibonaci(i-1) + fibonaci(i-2)
}
func main() {
   var i int
   for i = 0; i < 10; i++ {
      fmt.Printf("%d ", fibonaci(i))
   }
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

0 1 1 2 3 5 8 13 21 34