Could someone please explain what exactly recursion is (and how it works in Ruby, if that’s not too much to ask for). I came across a lengthy code snippet relying on recursion and it confused me (I lost it now, and it’s not entirely relevant).
Could someone please explain what exactly recursion is (and how it works in Ruby,
Share
A recursive function/method calls itself. For a recursive algorithm to terminate you need a base case (e.g. a condition where the function does not call itself recursively) and you also need to make sure that you get closer to that base case in each recursive call. Let’s look at a very simple example:
Some problems can be very elegantly expressed with recursion, e.g a lot of mathematical functions are described in a recursive way.