浅析python递归函数和河内塔问题

作者:JenneyForis 时间:2023-03-05 21:27:33 

关于递归函数:

函数内部调用自身的函数。

以n阶乘为例:

f(n) = n ! = 1 x 2 x 3 x 4 x...x(n-1)x(n) = n x (n-1) !


def factorial(n):
  if n==1:
    return 1
  return n * f(n-1)

//调用过程如下:


>>f(5)
>>5 * f(4)
>>5 * 4 * f(3)
>>5 * 4 * 3 * f(2)
>>5 * 4 * 3 * 2 * f(1)
>>5 * 4 * 3 * 2 * 1
>>120

从上面的例子可以直观得看到递归函数在不断的调用自己的函数,直到n==1(函数出口)。

关于河内塔:

规则:

1. 三根柱子,A,B, C

2. A 柱子上的盘子从小到大 排列,最上面的是最小的,最下面的是最大的。

3. 将A上的盘子移动到C上,移动过程中始终保持,最大的在下面,最小的在上面。

假设 A 柱子上有一个盘子,可以直接从A移动到C完成:

A --> C

假设 A 柱子上有两个盘子,需要借助B,移动到C:

A --> B

A --> C

B --> C

将A 最上面的盘(2-1)移动到B,然后将A中剩下一块盘移动到C,最后将B中的盘移动到C

假设 A 柱子上有三个盘子,需要借助B移动A 上面的两个盘,然后将A剩下最大的盘移动到C,最后将B中的盘移动到C。

A --> C

A --> B

C --> B  //这三步将A上前两个盘子移动到B

A --> C //这一步将A上最大的盘子移动到C

B --> A

B --> C

A --> C //后面这三步将B上的盘子移动到C

原理是将 A 上的(n-1) 块盘移动到B,然后A中剩下的,也是最大的一块盘移动到C,最后将B上(n-1)块盘移动到C。


def Hanoi(n , a, b, c):
 if n==1:
   print (" Hanoi Tower move", a, "-->", c)
   return
 Hanoi(n-1, a, c, b)
 Hanoi(1, a, b, c)
 Hanoi(n-1, b, a, c)
print (" When there is 1 ring on A")
Hanoi(1, 'A', 'B', 'C')
print (" When there are 2 rings on A")
Hanoi(2, 'A', 'B', 'C')
print (" When there are 3 rings on A")
Hanoi(3, 'A', 'B', 'C')
print(" When there are 4 rings on A")
Hanoi(4, 'A', 'B', 'C')

以上所述是小编给大家介绍的python递归函数和河内塔问题网站的支持!

来源:http://www.cnblogs.com/jenneyforis/archive/2017/04/18/6727135.html

标签:python,递归函数,河内塔
0
投稿

猜你喜欢

  • python 多线程实现检测服务器在线情况

    2021-12-11 15:15:58
  • python numpy中setdiff1d的用法说明

    2022-06-12 21:27:58
  • Python Http请求json解析库用法解析

    2021-11-20 14:05:45
  • Python使用GitPython操作Git版本库的方法

    2021-04-28 07:22:16
  • ASP和Javascript中取整函数的应用

    2009-06-07 18:38:00
  • vue el-table中使用el-select选中后无效的解决

    2024-04-26 17:37:54
  • Python实现去除列表中重复元素的方法小结【4种方法】

    2022-10-17 12:24:09
  • python 哈希表实现简单python字典代码实例

    2023-12-28 06:11:32
  • vuex页面刷新后数据丢失的方法

    2024-05-09 15:19:29
  • Python编程实现二叉树及七种遍历方法详解

    2022-10-31 13:28:28
  • Python中的基本数据类型讲解

    2021-04-29 07:07:24
  • Win11平台安装和配置NeoVim0.8.2编辑器搭建Python3开发环境详细过程(2023最新攻略)

    2023-06-06 21:28:07
  • 适合后台管理系统开发的12个前端框架(小结)

    2023-08-29 02:11:14
  • 对设计文档的一点小看法

    2010-03-15 12:30:00
  • 几行Python代码爬取3000+上市公司的信息

    2022-11-17 22:04:09
  • 在cmd中运行.py文件: python的操作步骤

    2021-10-01 08:40:47
  • python中字符串数组逆序排列方法总结

    2023-04-18 07:19:08
  • Python使用scapy模块发包收包

    2021-04-26 16:32:12
  • 使用Abot中文分词组件来开发ASP站内搜索引擎

    2007-10-18 13:36:00
  • Go 语言进阶单元测试示例详解

    2024-02-07 18:17:06
  • asp之家 网络编程 m.aspxhome.com