鱼C论坛

 找回密码
 立即注册
查看: 2410|回复: 1

[学习笔记] python复盘:023-024递归:这帮小兔崽子与汉诺塔

[复制链接]
发表于 2020-2-19 11:18:14 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 慕良 于 2020-2-19 12:07 编辑

023-024递归:这帮小兔崽子与汉诺塔

斐波那契(Fibonacci)数列的递归实现(分治思想)

例1:兔子的繁衍
月数 1 2 3 4 5 6 7 8 9 10 11 12
数量 1 1 2 3 5 8 13 21 34 5589 144

求20个月后的兔子数量。
迭代:
  1. def fab(n):
  2.     n1 = n2 = n3 = 1
  3.     if n < 1:
  4.         print('输入有误!')
  5.         return -1

  6.     while (n-2) > 0:
  7.         n3 = n2 + n1
  8.         n1 = n2
  9.         n2 = n3
  10.         n -= 1

  11.     return n3

  12. result = fab(20)
  13. if result != -1:
  14.     print('总共有%d对小兔崽子诞生!' % result)
复制代码

递归:
  1. def fab(n):
  2.     if n < 1:
  3.         print('输入有误!')
  4.         return -1
  5.     if n == 1 or n == 2:
  6.         return 1
  7.     else:
  8.         return fab(n-1) + fab(n-2)

  9. result = fab(20)
  10. if result != -1:
  11.     print('总共有%d对小兔崽子诞生!' % result)
复制代码


例2:汉诺塔
  1. def hanoi(n,x,y,z):#x,y,z代表3根针
  2.     if n == 1:
  3.         print(x,'-->',z)
  4.     else:
  5.         hanoi(n-1,x,z,y) #将前n-1个盘子从x移动到y上
  6.         print(x,'-->',z) #将最底下的最后一个盘子从x移动到z上
  7.         hanoi(n-1,y,x,z) #y上的n-1个盘子移动到z上

  8. n = int(input('请输入汉诺塔的层数:'))
  9. hanoi(n,'x','y','z')
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-2-19 12:26:06 | 显示全部楼层
很强
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-3 06:30

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表