views:

304

answers:

5

I am not sure but I had heard of an algorithm which can only be achieved by recursion. Does anyone know of such thing?

+1  A: 

If I remember my algorithms correctly, there is nothing doable by recursion that cannot be done with a stack and a loop. I don't have the formal proof here at my fingertips, however.

Edit: it occurs to me that the answer, possibly, is that the only thing doable by recursion that is not doable with a stack+loop, is a stack overflow?

Mark
Sure, you can produce a stackoverflow without recursion: Create a stack datastructure with limited capacity. Now keep pushing onto that stack until the capacity is exceeded. Stackoverflow. After all that's exactly what happens when you have infinite recursion (except that the stack whose capacity is exceeded is the processes's call stack instead of one you created explicitly within the program).
sepp2k
It was meant to be a joke, I apologize if it was not funny.
Mark
@Mark. No, sepp2k just seems to have set `senseOfHumor = false;`
AllenG
+17  A: 

You can always simulate recursion by keeping your own stack. So no.

sepp2k
Any recursive functions can be also converted to an equivalent iterative function.
quantumSoup
+1  A: 

The following compares a recursive vs non-recursive implementations: http://www.sparknotes.com/cs/recursion/whatisrecursion/section1.html

Excerpt:

Given that recursion is in general less efficient, why would we use it? There are two situations where recursion is the best solution:

  1. The problem is much more clearly solved using recursion: there are many problems where the recursive solution is clearer, cleaner, and much more understandable. As long as the efficiency is not the primary concern, or if the efficiencies of the various solutions are comparable, then you should use the recursive solution.
  2. Some problems are much easier to solve through recursion: there are some problems which do not have an easy iterative solution. Here you should use recursion. The Towers of Hanoi problem is an example of a problem where an iterative solution would be very difficult. We'll look at Towers of Hanoi in a later section of this guide.
Edward Leno
A: 

Are you just looking for a practical example of recursion? Recently my friends and I implemented the Haar Wavelet function (as an exercise to start learning Ruby), which seemed to require recursion. Unless anybody has an implementation of it without recursion?

I would imagine any time one doesn't know the depth of the stack one is iterating over, recursion is the logical way to go. Sure, it may be doable with some hacked up loops, but is that good code?

David
+8  A: 

You need to clarify what kind of recursion you are talking about. There's algorithmic recursion and there's recursion in the implementation. It is true that any recursive algorithm allows for a straightforward non-recursive implementation - one can easily do it by using the standard trick of simulating the recursion with manual stack.

However, your question mentions algorithms only. If one assumes that it is specifically about algorithmic recursion, then the answer is yes, there are algorithms that are inherently and unavoidably recursive. In general case it is not possible to replace an inherently recursive algorithm with a non-recursive one. The simplest way to build an inherently recursive algorithm is to take an inherently recursive data structure first. For example, let's say we need to traverse a tree with only parent-to-child links (and no child-to-parent links). It is impossible to come up with a reasonable non-recursive algorithm to solve this problem.

So, that's one example for you: traversal of a tree, which has only parent-to-child links cannot be performed by a non-recursive algorithm.

Another example of an inherently recursive algorithm is the well-known QuickSort algorithm. QuickSort is always recursive, and it cannot be turned into a non-recursive algorithm simply because if you succeed in doing this it will no longer be QuickSort anymore. It will be a completely different algorithm. Granted, this sounds as an exercise in pure semantics, but nevertheless that's also something that is worth mentioning.

AndreyT
Could you explain what you mean by "algorithmic recursion"? I've never heard that before. In regards to your quicksort comment: Are you saying that the "common" (constant space) implementation is not quicksort or that it is algorithmically recursive even if it is not actually recursive?
sepp2k
AndreyT
Also, I'm not aware of such thing as a constant-space QuickSort. A smart implementation of QuickSort requires `O(log n)` space. If we bring in the platform limitations (like the size of the largest array on given platform), we can, of course, limit the space by a relatively small constant, but that has very little do to with the algorithm itself. QuickSort is still (and always) recursive. As is Depth-First Search, for another example.
AndreyT