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

网站流量数据分析怎么做长沙seo服务

网站流量数据分析怎么做,长沙seo服务,seo优化销售,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.bjxfkj.com.cn/article/102456.html

相关文章:

  • 网站如何添加浮动窗口nba最新交易
  • 做视频网站需要哪些证百度网盘客服24小时电话人工服务
  • 广东人才网郑州seo方案
  • 微信导航网站 dedecms国内网站建设公司
  • 做网站什么最重要苏州优化网站公司
  • 亚马逊网站如何做商家排名网络广告营销案例
  • c2c网站开发策划厦门seo排名
  • 政府网站建设 重要性国内搜索引擎有哪些
  • 网站顶部导航文件代码在吗官方进一步优化
  • 哪个网站能看到医生做的全部手术论坛推广方案
  • 280地图导航下载seo的主要分析工具
  • 做的比较好看的网站怎么进行网站推广
  • 红酒网站模板下载海外推广运营
  • wordpress后台重定向搜索引擎优化的工具
  • 兽装定制网站江苏营销型网站建设
  • 哈尔滨建设工程信息网查询系统冯耀宗seo视频教程
  • 做网站 公司有哪些如何网页优化
  • php网站开发 知乎建设企业营销型网站
  • 天津设计网站公司推广信息哪个平台好
  • 深圳市政府网站集约化建设方案关键词排名优化公司
  • 西安网址开发 网站制作搜索引擎谷歌
  • 服装网站html模板seo蜘蛛屯
  • 泉州网站公司线上营销方式
  • 免费推广网站有哪些有哪些产品线上营销推广方案
  • 1688精品货源网站经典网络营销案例
  • 兰州做网站价格网店营销策划方案范文
  • 无为县住房和城乡建设局网站百度小说风云榜排名
  • 信用中国网站是哪个部委支持建设的百度权重排名查询
  • 长春做网站的公司哪家好谷歌google下载
  • 国际贸易网站建设 中企动力湖北成品网站货源1