定义
当一个函数用它自己来定义时就称为是递归的。
基本原则
1. 基本情形。必须总要有某些基准的情形,它们不用递归就能求解。
2. 不断推进。对于那些要递归求解的情形,递归调用必须总能够朝着一个基准情形推进。
递归算法解题思路
步骤分解,写出最后一次递归(n=1)的计算公式,然后倒数第二次(n=2,n=3,...),然后归纳出算法。
例1,汉诺塔问题
有A,B,C三根柱子。A柱子上从小到大的顺序堆放了N个盘子,现在要把全部盘子从A柱移到C柱,移动过程中可以借助B柱。移动时有如下要求:
(1),一次只能移动一个盘子;
(2),不允许把大盘放在小盘上边;
(3),盘子只能放在三根柱子上。
解题:
(1),把A柱上的N-1个盘子移动到B柱;
(2),把A柱上剩下的一个盘子移动到C柱;
(3),把B柱上面的N-1个盘子移动到C柱。
例2,给出一棵二叉树的中序和后序排列。求出它的先序排列
解法:
先序遍历是先访问根节点,再遍历左子树,最后遍历右子树;
中序遍历是先遍历左子树,再访问根节点,最后遍历右子树;
后序遍历是先遍历左子树,再遍历右子树,最后访问根结点。
从定义可知,后序遍历的最后一个字符即为这棵树的根节点;中序排列中,根节点前面的为其左子树,根结点后面的为其右子树。可以由后序遍历求得根结点,再由根结点在中序排列的位置确定左子树和右子树,把右子树和左子树各看作一棵单独的树。这样,就把一棵树分解为具有相同性质的两棵子树,已知递归下去,当分解的子树为空时,递归结束,在递归过程中,按先序遍历的规则输出求得的各个根结点,输出的结果即为原问题的解。