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

曼奇立德原画培训学费合肥seo推广公司哪家好

曼奇立德原画培训学费,合肥seo推广公司哪家好,电商课程,有什么要求汉诺塔 —— (经典分治递归) 一.汉诺塔介绍二.分治算法解决汉诺塔问题三.汉诺塔问题的代码实现四.主函数测试展示 一.汉诺塔介绍 汉诺塔问题源自印度一个古老的传说,印度教的“创造之神”梵天创造世界时做了 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.ds6.com.cn/news/102886.html

相关文章:

  • .com免费网站怎么做b2b免费发布信息平台
  • 班级网站 php百度seo还有前景吗
  • 建站系统和构建系统网络营销手段
  • 内江网站建设太原seo外包公司
  • 广东高职一流专业建设专题网站cps广告联盟网站
  • 展厅宣传片seo公司多少钱
  • wordpress load.php南京百度推广优化
  • 网站的工作简报怎么做sem是什么意思职业
  • 设计方案参考网站北京seo招聘网
  • 网站建设教程小说怎么做网站赚钱
  • 公司招聘一个网站建设来做推广一键制作单页网站
  • 白云区网站建设公司免费奖励自己的网站
  • 网站开发需求 模板百度热搜榜排名昨日
  • 如何进入网站后台地址百度宣传推广费用
  • 常州 网站 推广成都网站快速排名提升
  • 太原网站制作维护软文代写费用
  • 如何制作网站视频的软件seo优化推广多少钱
  • 开发电商平台多少钱北京网站优化站优化
  • 长春电商网站建设价格低郑州seo联系搜点网络效果好
  • 商城版免费网站制作优秀营销软文100篇
  • 龙华做棋牌网站建设哪家好seo的基础是什么
  • 一个网址的组成有哪些郑州seo外包顾问热狗
  • 专做奢侈品品牌的网站免费的网站推广方法
  • 做企业网站百度推广客服怎么打电话关键词快速排名不限行业
  • 南城网站建设流量平台
  • 微信网站开发哪家好百度竞价排名服务
  • 权威解读当前经济热点问题什么是seo?
  • 建个网站做网络推广要花多少钱百度竞价排名费用
  • 北京 做网站 公司培训机构seo
  • 如何做公司自己的网站中国制造网外贸平台