I've always found it useful to use indentation to indicate program calling depth. While it is very simple, that makes it easy to keep straight how many call frames are open at any point, and what they are. (All the statements from a particular call to the function should line up nicely.)
#!/usr/bin/perl -w
use strict;
my $recursion = 0;
sub hanoi {
my ($n, $start, $end, $extra) = @_;
$recursion++;
my $indent = " " x $recursion;
print $indent, "Entering hanoi($n, $start, $end, $extra)\n";
if ($n == 1) {
print $indent, "Move disk #1 from $start to $end.\n";
} else {
hanoi($n-1, $start, $extra, $end);
print $indent, "Move disk #$n from $start to $end.\n";
hanoi($n-1, $extra, $end, $start);
}
print $indent, "Leaving hanoi($n, $start, $end, $extra)\n";
$recursion--;
}
hanoi(3, 'A', 'C', 'B');
__END__
Entering hanoi(3, A, C, B)
Entering hanoi(2, A, B, C)
Entering hanoi(1, A, C, B)
Move disk #1 from A to C.
Leaving hanoi(1, A, C, B)
Move disk #2 from A to B.
Entering hanoi(1, C, B, A)
Move disk #1 from C to B.
Leaving hanoi(1, C, B, A)
Leaving hanoi(2, A, B, C)
Move disk #3 from A to C.
Entering hanoi(2, B, C, A)
Entering hanoi(1, B, A, C)
Move disk #1 from B to A.
Leaving hanoi(1, B, A, C)
Move disk #2 from B to C.
Entering hanoi(1, A, C, B)
Move disk #1 from A to C.
Leaving hanoi(1, A, C, B)
Leaving hanoi(2, B, C, A)
Leaving hanoi(3, A, C, B)
As the saying goes, to understand recursion you must first understand recursion. But hopefully this simple output will help you get that "ah hah!" moment where it starts to make sense.
-
Are you posting in the right place? Check out Where do I post X? to know for sure.
-
Posts may use any of the Perl Monks Approved HTML tags. Currently these include the following:
<code> <a> <b> <big>
<blockquote> <br /> <dd>
<dl> <dt> <em> <font>
<h1> <h2> <h3> <h4>
<h5> <h6> <hr /> <i>
<li> <nbsp> <ol> <p>
<small> <strike> <strong>
<sub> <sup> <table>
<td> <th> <tr> <tt>
<u> <ul>
-
Snippets of code should be wrapped in
<code> tags not
<pre> tags. In fact, <pre>
tags should generally be avoided. If they must
be used, extreme care should be
taken to ensure that their contents do not
have long lines (<70 chars), in order to prevent
horizontal scrolling (and possible janitor
intervention).
-
Want more info? How to link
or How to display code and escape characters
are good places to start.