当前位置: 首页 > news >正文

网站改版 被k装修网站建设公司

网站改版 被k,装修网站建设公司,wordpress 手动删除插件,网站栏目 英文汉诺塔 —— (经典分治递归) 一.汉诺塔介绍二.分治算法解决汉诺塔问题三.汉诺塔问题的代码实现四.主函数测试展示 一.汉诺塔介绍 汉诺塔问题源自印度一个古老的传说,印度教的“创造之神”梵天创造世界时做了 3 根金刚石柱,其中的一…

汉诺塔 —— (经典分治递归)

  • 一.汉诺塔介绍
  • 二.分治算法解决汉诺塔问题
  • 三.汉诺塔问题的代码实现
  • 四.主函数测试展示

一.汉诺塔介绍

汉诺塔问题源自印度一个古老的传说,印度教的“创造之神”梵天创造世界时做了 3 根金刚石柱,其中的一根柱子上按照从小到大的顺序摞着 64 个黄金圆盘。梵天命令一个叫婆罗门的门徒将所有的圆盘移动到另一个柱子上,移动过程中必须遵守以下规则:
每次只能移动柱子最顶端的一个圆盘;
每个柱子上,小圆盘永远要位于大圆盘之上;

图 1 给您展示了包含 3 个圆盘的汉诺塔问题:

在这里插入图片描述

图 1 汉诺塔问题

一根柱子上摞着 3 个不同大小的圆盘,那么在不违反规则的前提下,如何将它们移动到另一个柱子上呢?图 2 给大家提供了一种实现方案:

在这里插入图片描述

图 2 汉诺塔问题的解决方案

汉诺塔问题中,3 个圆盘至少需要移动 7 次,移动 n 的圆盘至少需要操作 2n-1 次。

在汉诺塔问题中,当圆盘个数不大于 3 时,多数人都可以轻松想到移动方案,随着圆盘数量的增多,汉诺塔问题会越来越难。也就是说,圆盘的个数直接决定了汉诺塔问题的难度,解决这样的问题可以尝试用分治算法,将移动多个圆盘的问题分解成多个移动少量圆盘的小问题,这些小问题很容易解决,从而可以找到整个问题的解决方案。

二.分治算法解决汉诺塔问题

为了方便讲解,我们将 3 个柱子分别命名为起始柱、目标柱和辅助柱。实际上,解决汉诺塔问题是有规律可循的:

1) 当起始柱上只有 1 个圆盘时,我们可以很轻易地将它移动到目标柱上;
2) 当起始柱上有 2 个圆盘时,移动过程如下图所示:

在这里插入图片描述

图 3 移动两个圆盘

移动过程是:先将起始柱上的 1 个圆盘移动到辅助柱上,然后将起始柱上遗留的圆盘移动到目标柱上,最后将辅助柱上的圆盘移动到目标柱上。

3) 当起始柱上有 3 个圆盘时,移动过程如图 2 所示,仔细观察会发现,移动过程和 2 个圆盘的情况类似:先将起始柱上的 2 个圆盘移动到辅助柱上,然后将起始柱上遗留的圆盘移动到目标柱上,最后将辅助柱上的圆盘移动到目标柱上。

通过分析以上 3 种情况的移动思路,可以总结出一个规律:对于 n 个圆盘的汉诺塔问题,移动圆盘的过程是:
1.将起始柱上的 n-1 个圆盘移动到辅助柱上;
2.将起始柱上遗留的 1 个圆盘移动到目标柱上;
3.将辅助柱上的所有圆盘移动到目标柱上。

由此,n 个圆盘的汉诺塔问题就简化成了 n-1 个圆盘的汉诺塔问题。按照同样的思路,n-1 个圆盘的汉诺塔问题还可以继续简化,直至简化为移动 3 个甚至更少圆盘的汉诺塔问题。

三.汉诺塔问题的代码实现

//将n个圆盘借助by从from移到to
void hanoi(int n, char from, char to, char by)
{void move(int n, char x, char y);if (n == 1)move(n, from, to);else{hanoi(n - 1, from, by, to);move(n, from, to);hanoi(n - 1, by, to, from);}
}void move(int n, char x, char y)
{printf("第%d个圆盘从%c->%c\n", n, x, y);
}int main() {int n = 0;printf("请输入A柱上圆盘个数:");scanf("%d", &n);//将n个圆盘借助C从A移到Bprintf("移动方法展示:\n");hanoi(n, 'A', 'B', 'C');return 0;
}

四.主函数测试展示

在这里插入图片描述
在这里插入图片描述

http://www.yayakq.cn/news/386812/

相关文章:

  • 平台网站做数据维护需要多久注册一个网页多少钱
  • 简述网站建设的流程青岛物联网app开发公司
  • 做棋牌网站违法嘛搭建购物商城
  • 环保网站建设网络推广方案微xiala11
  • 网站首页置顶是怎么做深圳服装网站建设制作开发
  • 山西智能建站系统价格网络最有效的推广方法
  • 贵阳网站建设培训百度搜索风云榜游戏
  • 东城网站建设公司忻州网站制作
  • 广西网站建设方案网站同时做竞价和优化可以吗
  • 找人做网站要准备什么软件wordpress单页导航
  • 找图片素材的网站有哪些网络推广公司起名
  • 淘宝客网站 备案网站设置为主页怎么设置
  • 网站域名备案和做网站wordpress 选择用户登录
  • 网站建设季度考核评价工作宁波seo软件
  • phpcms 生成网站地图做企业网站cms
  • 一个完整的工程项目流程seo流量工具
  • 国外直播做游戏视频网站搜狗提交网站收录入口
  • 提供建议的网站模板南阳网站关键词推广
  • 网站建设 讲话为什么简洁网站会受到用户欢迎
  • 邯郸市住房和建设官方网站商城模板html
  • 怎么做网站的轮播图dedecms wap网站模板下载
  • 巩义做网站的深圳营销型网站建设服务
  • 建设大学网站服务微信分销app
  • 买完域名怎么创建网站如何做建筑一体化的网站
  • 设计与网站建设案例做类似美团的网站吗
  • 石景山网站建设设计公司模版之家官网
  • 您的网站对百度设置了ip封禁织梦仿站时怎么取俩个网站的页面整合
  • 网站页尾设计html5网站优势
  • 厦门企业网站开发广州科 外贸网站建设
  • 高校网站建设 调查电商平台有哪些公司