29、Python 小案例

第7章 函数(上)

7.8.1 案例一

  • 编写两个函数,一个函数接收一个整数num为参数,生成杨辉三角形前num行数据,另一个函数接收生成的杨辉三角形并按以下形式输出,如图所示。

在这里插入图片描述

  • 在图中,列出了杨辉三角形的前9行。每一层左右两端的数都是1并且左右对称,从第1层开始,每个不位于左右两端的数等于上一层左右两个数相加之和。
  • 具体实现如例所示。

在这里插入图片描述

7.8.2 案例二

  • 汉诺塔问题是源于印度一个古老传说,大梵天创造世界时,在世界中心贝拿勒斯的圣庙中做了3根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘(称为汉诺塔)。大梵天命令婆罗门把圆盘从一根柱子上按大小顺序重新摆放在另一根柱子上,并规定在三根柱子之间一次只能移动一个圆盘且小圆盘上不能放置大圆盘,如图所示。

在这里插入图片描述

  • 假设使用1,2,3,…,n标记n个大小互不相同的圆盘,A、B、C标记3个柱子,初始状态时所有圆盘都放在A柱子上,最终状态时所有的圆盘都放在C柱子上,柱子B作为中间缓冲。

  • 当n = 1时,即只有1个圆盘,此时可以直接把这个圆盘从柱子A移动到柱子C,这也是递归的终止条件。

  • 当n > 1时,依次解决以下三个子问题:

  • 借助柱子C将前n-1个盘子从柱子A移到柱子B

  • 将圆盘n从柱子A移到柱子C

  • 借助柱子A将前n-1个圆盘从柱子B移到柱子C

  • 汉诺塔问题的具体实现如例所示。

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值