PHP递归实现汉诺塔问题的方法示例


Posted in PHP onNovember 25, 2017

本文实例讲述了PHP递归实现汉诺塔问题的方法。分享给大家供大家参考,具体如下:

汉诺塔(又称河内塔)问题是源于印度一个古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。简而言之,有三根相邻的柱子,标号为A,B,C,A柱子上从下到上按金字塔状叠放着n个不同大小的圆盘,要把所有盘子一个一个移动到柱子B上,并且每次移动同一根柱子上都不能出现大盘子在小盘子上方,请问至少需要多少次移动?

递归过程序如下:

1)把n-1个圆从A移到C
2)把剩下一个由A移到B
3)再把n-1个由C移到B,完成

代码如下:

<?php
//将所有圆盘从a移到b
function hanuota($n,$a,$b,$c){
  global $step;
  if($n==1){
    $step++;
    echo "将圆盘 $n 从 $a 柱子 到 $b 柱子 <br />";
  }else{
    hanuota($n-1,$a,$c,$b);
    $step++;
    echo "将圆盘 $n 从 $a 柱子 到 $b 柱子 <br />";
    hanuota($n-1,$c,$b,$a);
  }
}
//移动的次数
$step = 0;
hanuota(4, 'A', 'B', 'C');
echo "移动次数:" . $step;
?>

运行结果:

将圆盘 1 从 A 柱子 到 C 柱子
将圆盘 2 从 A 柱子 到 B 柱子
将圆盘 1 从 C 柱子 到 B 柱子
将圆盘 3 从 A 柱子 到 C 柱子
将圆盘 1 从 B 柱子 到 A 柱子
将圆盘 2 从 B 柱子 到 C 柱子
将圆盘 1 从 A 柱子 到 C 柱子
将圆盘 4 从 A 柱子 到 B 柱子
将圆盘 1 从 C 柱子 到 B 柱子
将圆盘 2 从 C 柱子 到 A 柱子
将圆盘 1 从 B 柱子 到 A 柱子
将圆盘 3 从 C 柱子 到 B 柱子
将圆盘 1 从 A 柱子 到 C 柱子
将圆盘 2 从 A 柱子 到 B 柱子
将圆盘 1 从 C 柱子 到 B 柱子
移动次数:15

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
利用文件属性结合Session实现在线人数统计
Oct 09 PHP
我的论坛源代码(一)
Oct 09 PHP
截获网站title标签之家内容的例子
Oct 09 PHP
php开发工具之vs2005图解
Jan 12 PHP
PHP代码优化的53个细节
Mar 03 PHP
php中curl和file_get_content的区别
May 10 PHP
destoon常用的安全设置概述
Jun 21 PHP
php计算税后工资的方法
Jul 28 PHP
表单提交错误后返回内容消失问题的解决方法(PHP网站)
Oct 20 PHP
php编程每天必学之表单验证
Mar 01 PHP
PHP实现的简单分页类及用法示例
May 06 PHP
PHP simplexml_import_dom()函数讲解
Feb 03 PHP
PHP基于curl post实现发送url及相关中文乱码问题解决方法
Nov 25 #PHP
php图片合成方法(多张图片合成一张)
Nov 25 #PHP
PHP简单实现二维数组的矩阵转置操作示例
Nov 24 #PHP
PHP实现图的邻接矩阵表示及几种简单遍历算法分析
Nov 24 #PHP
PHP+Apache环境中如何隐藏Apache版本
Nov 24 #PHP
实例分析基于PHP微信网页获取用户信息
Nov 24 #PHP
thinkPHP通用控制器实现方法示例
Nov 23 #PHP
You might like
Thinkphp模板中截取字符串函数简介
2014/06/17 PHP
PHP实现二叉树深度优先遍历(前序、中序、后序)和广度优先遍历(层次)实例详解
2018/04/20 PHP
php实现记事本案例
2020/10/20 PHP
Javascript new关键字的玄机 以及其它
2010/08/25 Javascript
ExtJs GridPanel简单的增删改实现代码
2010/08/26 Javascript
基于Jquery的仿照flash放大图片效果代码
2011/03/16 Javascript
Extjs改变树节点的勾选状态点击按钮将复选框去掉
2013/11/14 Javascript
jQuery操作input值的各种方法总结
2013/11/21 Javascript
Python脚本后台运行的几种方式
2015/03/09 Javascript
jQuery实现的Tab滑动选项卡及图片切换(多种效果)小结
2015/09/14 Javascript
简单解析JavaScript中的__proto__属性
2016/05/10 Javascript
轻松掌握JavaScript装饰者模式
2016/08/27 Javascript
Express与NodeJs创建服务器的两种方法
2017/02/06 NodeJs
AngularJS遍历获取数组元素的方法示例
2017/11/11 Javascript
深入Vue-Router路由嵌套理解
2018/08/13 Javascript
跟混乱的页面弹窗说再见
2019/04/11 Javascript
Vue.extend 编程式插入组件的实现
2019/11/18 Javascript
javascript 模块依赖管理的本质深入详解
2020/04/30 Javascript
jQuery 函数实例分析【函数声明、函数表达式、匿名函数等】
2020/05/19 jQuery
[05:04]DOTA2上海特级锦标赛主赛事第二日TOP10
2016/03/04 DOTA
Python中的一些陷阱与技巧小结
2015/07/10 Python
python使用两种发邮件的方式smtp和outlook示例
2017/06/02 Python
Python基于opencv实现的简单画板功能示例
2019/03/04 Python
django实现日志按日期分割
2020/05/21 Python
DBA的职责都有哪些
2012/05/16 面试题
Linux文件操作命令都有哪些
2016/07/23 面试题
高分子材料与工程专业个人求职信
2013/12/15 职场文书
五型班组建设方案
2014/02/10 职场文书
高中教师考核方案
2014/05/18 职场文书
2015年化验员工作总结
2015/04/10 职场文书
2015银行年终工作总结范文
2015/05/26 职场文书
对学校的意见和建议
2015/06/04 职场文书
2015年公司国庆放假通知
2015/07/30 职场文书
聘任书格式及范文
2015/09/21 职场文书
怎样写好演讲稿题目?
2019/08/21 职场文书
python高温预警数据获取实例
2022/07/23 Python