1 / 6
文档名称:

汉诺塔问题实验报告.doc

格式:doc   大小:70KB   页数:6页
下载后只包含 1 个 DOC 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

汉诺塔问题实验报告.doc

上传人:feng1964101 2020/8/7 文件大小:70 KB

下载得到文件列表

汉诺塔问题实验报告.doc

文档介绍

文档介绍::通过本实验,掌握复杂性问题的分析方法,了解汉诺塔游戏的时间复杂性和空间复杂性。:  汉诺塔问题来自一个古老的传说:在世界刚被创建的时候有一座钻石宝塔(塔A),其上有64个金碟。所有碟子按从大到小的次序从塔底堆放至塔顶。紧挨着这座塔有另外两个钻石宝塔(塔B和塔C)。从世界创始之日起,婆罗门的牧师们就一直在试图把塔A上的碟子移动到塔C上去,其间借助于塔B的帮助。每次只能移动一个碟子,任何时候都不能把一个碟子放在比它小的碟子上面。当牧师们完成任务时,世界末日也就到了。:    对于汉诺塔问题的求解,可以通过以下三个步骤实现:    (1)将塔A上的n-1个碟子借助塔C先移到塔B上。    (2)把塔A上剩下的一个碟子移到塔C上。    (3)将n-1个碟子从塔B借助于塔A移到塔C上。:用c++或c语言设计实现汉诺塔游戏;让盘子数从2开始到7进行实验,记录程序运行时间和递归调用次数;画出盘子数n和运行时间t、递归调用次数m的关系图,并进行分析。:#include""#include<>#include<>#include<iostream>voidhanoi(intn,charx,chary,charz){ if(n==1) { printf("从%c->搬到%c\n",x,z); } else { hanoi(n-1,x,z,y); printf("从%c->%c搬到\n",x,z); hanoi(n-1,y,x,z); }}voidmain(){ intm; printf("inputthenumberofdiskes:"); scanf("%d",&m); printf("Thesteptomoving%3ddiskes:",m); hanoi(m,'a','b','c');}自定义头文件:#pragmaonce#include""#include<>#include<>结果如下:)Hanoi塔问题中函数调用时系统所做工作一个函数在运行期调用另一个函数时,在运行被调用函数之前,系统先完成3件事:①将所有的实参、返回地址等信息传递给被调用函数保存。②为被调用函数的局部变量分配存储区;③将控制转移到被调用函数的入口。从被调用函数返回调用函数前,系统也应完成3件事:①保存被调用函数的结果;②释放被调用函数的数据区;③依照被调用函数保存的返回地址将控制转移到调用函数。当有多个函数构成嵌套调用时,按照“后调用先返回”的原则(LIFO),上述函数之间的信息传递和控制转移必须通过“栈”来实现,即系统将整个程序运行时所需的数据空间安排在一个栈中,每当调用一个函数时,就为其在栈顶分配一个存储区,每当从一个函数退出时,就释放其存储区,因此当前运行函数的数据区必在栈顶。堆栈特点:LIFO,除非转移或中断,堆栈内容的存或取表现出线性表列的性质。正是如此,程序不要求跟踪当前进入堆栈的真实单元,而只要用一个具有自动递增或自动递减功能的堆栈计数器,便可正确指出最后一次信息在堆栈中存放的地址。一个递归函数的运行过程类型于多个函数的嵌套调用,只是调用函数和被调用函数是同一