欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    人工智能(梵塔问题).doc

    • 资源ID:34334048       资源大小:67.50KB        全文页数:8页
    • 资源格式: DOC        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    人工智能(梵塔问题).doc

    如有侵权,请联系网站删除,仅供学习与交流人工智能(梵塔问题)【精品文档】第 8 页梵塔问题实验报告实验目的1. 熟悉和掌握问题规约法的原理、实质和规约过程2. 理解规约图的表示方法3. 熟悉并掌握递归解决问题的思想实验原理1. 利用问题规约法的原理进行问题的分析与描述2. 利用递归思想进行问题的解决实验条件1. Window NT/xp/7及以上的操作系统2. 内存在512M以上3. CPU在奔腾II以上实验内容梵塔问题源于印度古老的一个传说。相传开天辟地的神勃拉玛创造世界时在印度北部的佛教圣地的圣庙里,安放了三根金刚石的棒,第一根上面套着64个圆的金片,最大的一个在底下,其余一个比一个小,依次叠上去,庙里的众僧不倦地把它们一个个地从这根棒搬到另一根棒上,规定可利用中间的一根棒作为帮助,但每次只能搬一个,而且大的不能放在小的上面。值班僧侣按照法则日夜不停地搬运,当搬运完成时世界将在一声霹雳中毁灭。实验分析我们假设把该任务交给一个僧人,为了方便叙述,将他编号为64。僧人自然会这样想:假如有另外一个僧人能有办法将63个盘子从一个座移到另一个座,那么问题就解决了,此时僧人64只需这样做:1. 命令僧人63将63个盘子从A座移到C座2. 自己将最底下的最大的一个盘子从A座移到C座3. 再命令僧人63将63个盘子从B座移到C座为了解决将63个盘子从A座移到B座的问题,僧人63又想:如果能再有一个僧人62能将62个盘子移动到另一座,我就能将63个盘子从A座移动到B座。他是这样做的:1. 命令僧人62将62个盘子从A移动到C2. 自己将一个盘子从A座移动到B座3. 再命令僧人62将62个盘子移到B座再进行一次递归。如此“层层下放”,直到后来找到第2个僧人,让他完成将2个盘子从一个座移到另一个座,进行到此,问题就解决了。最后找到第1个僧人,让他完成将一个盘子从一个座移动到另一个座,至此,全部工作已经完成,该烦他问题得到解决。实验步骤 主程序流程图初始化过程绘制初始图形汉诺塔求解开始输入盘子数结束主程序流程图 梵塔求解流程图开始将盘子从A座移到C座n为1?是否递归调用,初始n=n-1盘子数为n结束梵塔问题递归过程流程图退出一级调用n=n+1程序代码#include <stdio.h>#include <graphics.h>#include <time.h>#include <dos.h>#include <math.h>#define PAOGAO 190 /*动画抛高,数值越小越高*/#define PANHOU 10/*#define PANAMOUNT 19盘子数*/ int PANAMOUNT;typedef int pans;typedef struct s_pillar int amount; int x,y; pans pan20; /*存放每个盘的代号*/pillars;pillars pillar4; /*三个台柱*/int movecount=0; /*移动计数*/void drawpillar(pillars p);void init(); /*初始化函数*/void drawmat(char *mat,int matsize,int x,int y,int color); /* 点陈汉字 */void drawpan(pans p,int x,int y);void zimu(); /*显示字幕*/void drawpps(); /*画装盘的台柱*/void hanoi(); /*主算法*/void hanoi(int n,char one,char two,char three);void sdelay(int delay_t); /*函数申明*/void finish(); /*完成!*/void main(void) /*主函数*/ printf("ntplease input n(n<=19): ");/*输入要演示的盘子数*/ scanf("%d",&PANAMOUNT); if(PANAMOUNT<1|PANAMOUNT>19) /*越界的话n当19处理*/ PANAMOUNT=19 ; init(); drawpps(); hanoi(PANAMOUNT,'a','b','c'); finish();void init() /* 初始化函数 */ int gd=DETECT,gm ; int i,n,color ; clrscr(); initgraph(&gd,&gm,"c:tc"); cleardevice(); pillar1.amount = PANAMOUNT; pillar1.x = 105; pillar1.y = 405; for(i=1;i<=pillar1.amount;i+) pillar1.pani=pillar1.amount-i+1; pillar2.amount = 0; pillar2.x = 320; pillar2.y = 405; pillar3.amount = 0; pillar3.x = 527; pillar3.y = 405; setcolor(YELLOW); /*柱座标记*/ settextstyle(0,0,2); outtextxy(105,418,"A"); outtextxy(320,418,"B"); outtextxy(527,418,"C"); setcolor(YELLOW); /*画框*/ setlinestyle(SOLID_LINE,0,NORM_WIDTH); line(0,0,0,479); line(0,0,639,0); line(639,0,639,479); line(0,479,639,479); line(0,PAOGAO-PANHOU-40,450,PAOGAO-PANHOU-40); /*黄金线*/ settextstyle(0,0,1); outtextxy(250,PAOGAO-PANHOU-50,"Press ANY Key to EXIT !"); /*线上字*/ zimu();void drawpillar(pillars p) /*画柱*/ int x,y,mount; x=p.x; y=p.y; mount=p.amount; setfillstyle(SOLID_FILL,BROWN); bar(x,(y-mount*PANHOU-20),x+5,y); bar(x-45,y,x+55,y+5);void drawmat(char *mat,int matsize,int x,int y,int color)/*依次:字模指针、点阵大小、起始坐标(x,y)、颜色*/int i,j,k,n; n=(matsize-1)/8+1; for(j=0;j<matsize;j+) for(i=0;i<n;i+) for(k=0;k<8;k+) if(matj*n+i&(0x80>>k) /*测试为1的位则显示*/ putpixel(x+i*8+k,y+j,color);void drawpan(pans p,int x,int y) setfillstyle(SOLID_FILL,LIGHTGRAY); bar(x-(5+5*p),y-PANHOU+1,x+(5+5*p),y); setlinestyle(SOLID_LINE,0,NORM_WIDTH); setcolor(BLACK); line(x-(5+5*p),y,x+(5+5*p),y); line(x-(5+5*p),y+1,x+(5+5*p),y+1);void clearpan(pans p,int x,int y) setfillstyle(SOLID_FILL,BLACK); bar(x-(5+5*p),y-PANHOU,x+(5+5*p),y);void drawpps() /*画装盘的台柱*/ pillars p; int i,j; int x,y,mount; for(i=1;i<=3;i+) p = pillari; x = p.x; y = p.y; mount = p.amount; drawpillar(p); /*画台柱*/ for(j=1; j<=mount ;j+) drawpan(p.panj,x,y-PANHOU*(j-1);void hanoi(int n,char one,char two,char three) void move(char x,char y); /*声明*/ if(n=1) move(one,three); else hanoi(n-1,one,three,two); move(one,three); hanoi(n-1,two,one,three);void move(char x,char y) void clearprocess(); /*申明函数*/ void action(); /*申明移动动画函数*/ int ifrom,ito; pans data; int mountf,mountt; char a1; char b1; a0=x;a1='0' b0=y;b1='0' ifrom = x-96; ito = y-96; mountf = pillarifrom.amount; /*数量*/ mountt = pillarito.amount; data = pillarifrom.panmountf; pillarifrom.amount-; /*出栈*/ sdelay(6); /*暂停屏幕*/ if(movecount>=15) clearprocess();/*清除步骤提示*/ movecount = movecount%15+1; /*模20+1*/ setcolor(RED); /*输出移动过程*/ settextstyle(TRIPLEX_FONT, HORIZ_DIR, 1); outtextxy(560,30+movecount*10,a); outtextxy(580,30+movecount*10,"->"); outtextxy(620,30+movecount*10,b); setfillstyle(SOLID_FILL,BLACK);/*涂黑_重画*/ bar(3,pillar1.y-PANHOU*19-20,584,412); drawpps(); /*重画*/ action(data,pillarifrom,pillarito);/*此处添加动画函数*/ pillarito.amount+; /*入栈*/ mountt = pillarito.amount;/*刷新数量*/ pillarito.panmountt = data; drawpps(); /*重画*/void clearprocess() int i; setfillstyle(SOLID_FILL,BLACK); for(i=0;i<=16;i+) bar(545,30+i*10,638,40+i*10); sdelay(1); /*动画延迟n个(1/18.2)秒*/整数1代表(1/18.2)秒 */void sdelay(int delay_t) clock_t start_time ; start_time=clock(); while(clock()-start_time)<delay_t) ; /*循环空语句*/void action(pans pan,pillars fromp,pillars top) /*移动动画*/ float x1,y1,x2,y2; float p,q,a; int x,y,temp; /*整形变量用与当前帧*/ x1 = (float)(fromp.x); y1 = (float)(fromp.y - fromp.amount*PANHOU -20); /*PANHOU为盘厚常数,减20处理,以便避开柱子*/ x2 = (float)(top.x); y2 = (float)(top.y - top.amount*PANHOU); q = -sqrt(y1-PAOGAO)/(y2-PAOGAO); /*此处注意产生增根*/ if(1-q) /*除数不为0*/ a = (x1 - x2*q)/(1-q); else a = (x1+x2)/2.0; p = (y2-PAOGAO)/(x2-a)/(x2-a);/*除以平方*/ if(x1 <= x2) for(x=floor(x1+0.5); x<floor(x2+0.5); x=x+ 7 ) if(kbhit() exit(); /*用户按ESC则退出*/ y =floor(p*(x-a)*(x-a)+PAOGAO)+0.5); drawpan(pan,x,y); sdelay(1); clearpan(pan,x,y);/*清除轨迹*/ else for(x=floor(x1+0.5); x>floor(x2+0.5); x=x- 7 ) if(kbhit() exit(); /*用户按ESC则退出*/ y = floor(p*(x-a)*(x-a)+PAOGAO)+0.5); drawpan(pan,x,y); sdelay(1); clearpan(pan,x,y);/*清除轨迹*/void finish() /*完成!*/ getch(); closegraph();程序运行效果图个人实验小结通过本次实验,我学会了熟悉并掌握问题规约法的原理、实质和规约过程,理解了规约图的表示方法,熟悉并掌握递归解决问题的思想。使我的软件编程思维能力得到了很大的提升,使我的自身能力有了长足的进步。

    注意事项

    本文(人工智能(梵塔问题).doc)为本站会员(豆****)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开