递归问题(Recursive)

定义

当一个函数用它自己来定义时就称为是递归的。

基本原则

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,给出一棵二叉树的中序和后序排列。求出它的先序排列

解法:

先序遍历是先访问根节点,再遍历左子树,最后遍历右子树;

中序遍历是先遍历左子树,再访问根节点,最后遍历右子树;

后序遍历是先遍历左子树,再遍历右子树,最后访问根结点。

从定义可知,后序遍历的最后一个字符即为这棵树的根节点;中序排列中,根节点前面的为其左子树,根结点后面的为其右子树。可以由后序遍历求得根结点,再由根结点在中序排列的位置确定左子树和右子树,把右子树和左子树各看作一棵单独的树。这样,就把一棵树分解为具有相同性质的两棵子树,已知递归下去,当分解的子树为空时,递归结束,在递归过程中,按先序遍历的规则输出求得的各个根结点,输出的结果即为原问题的解。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值