第6章 递归——自己定义自己
汉诺塔问题
递推公式(recursion relation, recurrence)
解析式:只使用n表示H(n)的式子。
在问题中找出递归结构——> 建立递归公式
阶乘的递归定义:n!=n×n(n-1)!
递归和归纳:
同:都是“将复杂问题简化”;
异:“从一般性前提退出个别性结论”——递归;“从个别性前提推出一般性结论”——归纳。
斐波那契数列
思考题:不断繁殖的动物
斐波那契数列例子:
摆砖头、创作旋律、鹦鹉螺的内壁间隔、葵花种子的排法、植物枝叶的长法、“一次走1阶或2阶,爬n层阶梯的方法”
帕斯卡三角形:每个数字都是上方与它相邻的两数之和。

帕斯卡三角形中出现组合数的原因:“相邻两数相加”和“n中选k的组合数”的计算对象相同。
递归定义组合数:

组合的数学分析法
找出问题中的递归结构的步骤:
从n层的整体问题中隐去部分问题 -> 判断剩余部分是否是n-1层的问题
递归图形:树、谢尔平斯基三角形(Sierpinski gasket, Sierpinski triangle)

分形图:含有递归结构的图形。
本文探讨了递归的概念及其在计算机科学中的应用,通过汉诺塔问题、阶乘、斐波那契数列等经典实例,揭示了递归在解决复杂问题中的魅力。同时介绍了递归与归纳的区别,并展示了如何在实际问题中寻找递归结构。
529

被折叠的 条评论
为什么被折叠?



