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

c 做网站加载多个图片手机网站制作公司选哪家

c 做网站加载多个图片,手机网站制作公司选哪家,网站推广优化怎样,优秀设计案例介绍 汉诺塔是源于印度的一个古老传说的小游戏,简单来说就是有三根柱子,开始的时候,第一根柱子上圆盘由大到小,自下往上排列。这个小游戏要实现的目的呢,就是要把第一根柱子上的圆盘移到第三根的柱子上去;…

介绍

汉诺塔是源于印度的一个古老传说的小游戏,简单来说就是有三根柱子,开始的时候,第一根柱子上圆盘由大到小,自下往上排列。这个小游戏要实现的目的呢,就是要把第一根柱子上的圆盘移到第三根的柱子上去;条件呢,就是在移动过程当中不能将大的圆盘放在小的圆盘上面,我们可以利用中间第二根柱子作为桥梁来承接我们要移动的圆盘。

而在这个传说当中,一共有64块圆盘,假设我们使用递归的方法,我们也得用18446744073709551615的步数来实现我们的目的,换算成时间呢,我们得花5845.42亿年来实现这个过程。

算法思路

实现这个小游戏的算法思路是什么呢?

我们一定要将最大的那块圆盘放到C柱那里去,那么我们的目的就很明确,我们倒着思考一下,最后那几步的时候,我们是要将上面的n-1块圆盘移动到中间的柱子上,最后再将n-1块圆盘放到C柱上的。

假设我们这里有三块圆盘,我们先将A盘上的两块小圆盘移到B盘上去

再将A柱上最大的圆盘移动到C柱上

再将B柱上的圆盘放回C住上,最后大功告成

那在这一步的前一步呢,那不就是n-2块了吗,对于前面的步骤,都是和最后的类似,那最后一步我们走了几步呢?假设我们有一个表达式能描述移动的步数,那么f(n)=2*f(n-1)+1,f(1)=1,f(0)=0

为什么会有这个表达式呢,我们先移动了n-1块盘到B柱,再将n-1块盘到C柱,这里我们就可以得到2*f(n-1),我们还将最下面的那个盘子放到了C盘这里,所以我们在这里得加一。

最后我们可以得到步数的结果为f(n)=2^n-1

其它方法

美国学者曾提出过一种更为简洁的方法:首先把三根柱子按顺序排成品字型,把所有的圆盘按从大到小的顺序放在柱子A上,根据圆盘的数量确定柱子的排放顺序:

  • 若n为偶数,按顺时针方向依次摆放 A B C
  • 若n为奇数,按顺时针方向依次摆放 A C B

步骤

  1. 按顺时针方向把圆盘1从现在的柱子移动到下一根柱子,即当n为偶数时,若圆盘1在柱子A,则把它移动到B;若圆盘1在柱子B,则把它移动到C;若圆盘1在柱子C,则把它移动到A。 

  2. 接着,把另外两根柱子上可以移动的圆盘移动到新的柱子上。即把非空柱子上的圆盘移动到空柱子上,当两根柱子都非空时,移动较小的圆盘。这一步没有明确规定移动哪个圆盘,你可能以为会有多种可能性,其实不然,可实施的行动是唯一的。

  3. 反复进行⑴⑵操作,最后就能按规定完成汉诺塔的移动。

 代码实现

python

def f(n):if n==0:return 0else:return 2*f(n-1)+1
x=int(input("请输入片的个数:"))
print("需要移动",f(x),"次")
def hanoi(n, a, b, c):if n == 1:print(a, '-->', c)else:hanoi(n - 1, a, c, b)print(a, '-->', c)hanoi(n - 1, b, a, c)
# 调用
hanoi(5, 'A', 'B', 'C')

cpp

#include <iostream> using namespace std; void hanoi(int n, char source, char help, char target){static int step = 0; if (n == 1)std::cout << (++step) << ": " << source << "---->" << target << endl; else{// move n-1 disks from source to help hanoi(n-1, source, target, help); std::cout <<(++step) << ": " << source << "---->" << target << endl; hanoi(n-1, help, source, target);}
}
int main(void){hanoi(10, 'a', 'b', 'c');return 0; 
}

C

#include <stdio.h>
#include <windows.h>
void Hanoi(int n, char a,char b,char c);
void Move(int n, char a, char b);
int count;
int main()
{int n=8;printf("汉诺塔的层数:\n");scanf(" %d",&n);Hanoi(n, 'A', 'B', 'C');Sleep(20000);return 0;
}
void Hanoi(int n, char a, char b, char c)
{if (n == 1){Move(n, a, c);}else{Hanoi(n - 1, a, c, b);Move(n, a, c);Hanoi(n - 1, b, a, c);}
}
void Move(int n, char a, char b)
{count++;printf("第%d次移动 Move %d: Move from %c to %c !\n",count,n,a,b);
}

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

相关文章:

  • 网站建设开发费入什么科目国外自助建站
  • 方山建站报价wordpress 用户后台
  • 求职网站网页设计陕西网站建设网络公司
  • 宝塔Linux面板清理建设的网站如何制作一个网站
  • 网站建设合同甲乙双方怎么确定百度指数免费添加
  • 喀什市建设局网站查证件建设个人网站流程
  • 网站宣传册怎么做wordpress 不发布文章
  • 欧美设计网站推荐网站开发需要学多久
  • 永安市建设局网站六图网
  • 广东建网站公司wordpress自定义右侧不显示页面
  • 如何建设网站兴田德润怎么样wordpress主机要求
  • 用xmind做网站架构代理合同
  • 做网站联系附子seo教程
  • 北京公司的网站建设商务网站建设的必备功能
  • 大屏网站模板WordPress数据库名要填什么
  • 结构设计网站网站开发哪里安全
  • 短链接一键生成塘沽网站优化
  • 重庆营销网站制作网站维护管理
  • 开平市网站建设网站数据分析的重要性
  • 怎么样模仿一个网站做简历百度seo分析工具
  • 上海网站建设 s海外服务器租用平台
  • 如何用织梦做网站详细教程门户网站建设 增强责任意识
  • 邢台网站推广电商名字创意名称
  • 网站关键词分割wordpress企业模板中文版
  • 网站建设的进度表潍坊网站的公司电话
  • 自己做的小网站分享wordpress网页打开慢
  • 电商网站开发思路模版杭州有实力的网站开发
  • php开发的大型网站有哪些wordpress忘记以前版本
  • 连云港专业网站优化网站开发中怎么样对接接口
  • 青岛网站设计公司电话关键词词库