第三课:递归的三个例子
概述 前文中讲解了递归的运行机制,并讲解了简单的递归情况。从程序设计的角度来将,递归其实是现代程序设计不可或缺的一种方法,对于很多问题,用递归可能是一种较为合适的解决方法。但是如何设计递归需要设计或者求解出递推公式,才能转换为递归,其中的重点是设计递推公式。本文如下部分讲解三个例子,一个是人人皆知的汉诺塔,一个是求排列,一个是求整数划分,重点讲解如何设计递归公式。更详细的代码请见我的github 例1:汉诺塔 汉诺塔是学程序设计的童鞋必备的一环,其约束为:始终保持小圆盘不能在大圆盘之上,从一根柱子一到另一根柱子,中间可以借助一根柱子,示意图如图1所示: 图1:汉诺塔示意图,摘自维基百科 直觉上这应该是一个递归问题,但是如何设计递推公式是很多童鞋觉得比较头疼的问题。设计递推公式的本质就是形式化...阅读全文