This is code from a book I have explaining recursion. The problem is that I don't understand the steps taken by the program:
var hanoi = function(disc,src,aux,dst) {
if (disc > 0) {
hanoi(disc - 1,src,dst,aux);
document.write("Move disc " + disc + " from " + src + " to " + dst + "<br />");
hanoi(disc - 1,aux,src,dst);
}
};
hanoi(3,"src","aux","dst");
This is how the Output reads:
Move disc 1 from src to dst
Move disc 2 from src to aux
Move disc 1 from dst to aux
Move disc 3 from src to dst
Move disc 1 from aux to src
Move disc 2 from aux to dst
Move disc 1 from src to dst
Can someone break this down step by step? It would be very helpful to me.
Probably the simplest solution to the Towers of Hanoi works like this:
To move
x
discs from peg A to peg C, using peg B as an "aux" peg:x-1
discs from peg A to peg B, using peg C as the aux peg.x
'th disc from peg A to peg C (no aux peg needed, cause you're only moving one disc).x-1
discs from peg B to peg C, using peg A as the aux peg.Note that in order to move
x
discs, you have to movex-1
discs. You can just use the same function to move thosex-1
discs, and just switch which pegs are the source, dest, and aux pegs. That's what makes Towers of Hanoi such a common example of recursion, and that's the kind of pattern you need to see in a problem in order to make recursion work for you. It need not be "movex-1
discs", of course...it could be something like "list this subfolder". Trees (like a directory with subfolders and such) are another place where recursion shines. As do other jobs where in order to do the job on an item, you may need to do the same job on sub-items.Now, in order to have useful recursion, you need a "base case" -- a condition where the recursion will stop. If you don't, the code will run forever (or at least til it runs out of memory or overflows the call stack). The base case here occurs when
x == 0
(since moving 0 discs means you do nothing, due to theif
around the meat of the function). It could also be whenx == 1
, as then you don't have to recurse, but the extraif
before eachhanoi
call would add a bit of noise (and the main benefit to a recursive solution is its simplicity). Anyway, whenx == 0
, the function returns without doing anything. The function that called it (which hadx == 1
) now gets to continue doing its thing -- in this case, saying "move disc 1 from src to dest", and then calling thehanoi
function again with the args switched.The flow goes a bit like this:
I've figured it out. When broken down, the code runs as follows:
The most confusing part about this was visualizing the END of the first recursive loop. Only when disc == 0 does the statement with disc == 3 finally get written.