欢迎来到优知文库! | 帮助中心 分享价值,成长自我!
优知文库
全部分类
  • 幼儿/小学教育>
  • 中学教育>
  • 高等教育>
  • 研究生考试>
  • 外语学习>
  • 资格/认证考试>
  • 论文>
  • IT计算机>
  • 法律/法学>
  • 建筑/环境>
  • 通信/电子>
  • 医学/心理学>
  • ImageVerifierCode 换一换
    首页 优知文库 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    bfs解决宝葫芦问题——解题报告 广搜(bfs)算法.docx

    • 资源ID:1434879       资源大小:12.70KB        全文页数:5页
    • 资源格式: DOCX        下载积分:3金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: QQ登录
    二维码
    扫码关注公众号登录
    下载资源需要3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,如果您不填写信息,系统将为您自动创建临时账号,适用于临时下载。
    如果您填写信息,用户名和密码都是您填写的【邮箱或者手机号】(系统自动生成),方便查询和重复下载。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

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

    bfs解决宝葫芦问题——解题报告 广搜(bfs)算法.docx

    八宝葫芦问题解即报告题目:宝葫芦被放在一个城堡里.城维由Mm个方格组成,你只能从当前所在的方格跳到相邻的4个方格电,而且不能跳出城堡的莅If1.城堡中某些方格里有弹簧每个弹簧具有一个特定能fitp.不同弹簧的P值不旨定相同。假如你跳到一个行弹簧的方格.就会立即沿着原来运动的方向接着跳P格.假如跳到的方格里又有冲筑,就立刻接着跳,百.到跳到一个空的方格或者被墙拦住无法接莉前进为止.你能否尽快找到宝葫芦吗?输入:第一行有两个整数.n和m(3=<n,m<=100)分别是城堡的行数和列数,其后是一个非负整数k,表示弹雷的个数,在接下来的k行里,姆行有三个正数x,yp.以空格隔开.其中X和y是弹质的坐标<2=vv=n-l,2=vyv=m-l),P是弹簧的能依.在下面的两行里,分别是你和宝葫芦的坐标.此外,你在空中没过的弹黄对你没有任何影响,已知你、宝葫芦和弹簧的初始位置都不同。X坐标轴的范用是1到n,V坐标轴的范附是1到m.有多组测试用例.输出:最少的步数,或者ImpoSSlble题目来源:bit网络教室解题思路:首先明确这是个搜寻何胭,并且不须要记录路径,即么就不须要要用深挖并且深搜须要搜寻完全部的点才能却确定出报小的解,这个代价是很大的,所以应当选择广搜(bfs).在搜寻的时候,建立队列.把人的起点都放在队列的起先,然后从它起先搜寻,搜都的点放在队列圾,然后从队列里取侦搜索.直到到搜到宝葫芦为止,最少的步数就是搜寻的层数.若果搜寻完队列里的全部元素.还没有找到宝葫芦,加么就是impossible.须娈留意的细微环节:1)当你跌到弹簧的时候,肯定蹙把此次弹烫跌的终点存在队列里,而不是把弹簧的坐标行在队列里面.2)弹费可能被用多次,跳过之后不要删网上代码,仅供卷考:7Windude<stdio.h>Winclude<math.h>defineN105intnzm,flag;intfront,rear;intspringNN,map(N11N1.ppNN)springHffmapUU标记是否搜过,0还没碰过,1-看到了,2搜过了;PpU该点至少跳几次才到structpointintx;inty;;structpointe11d,pN*Nj;voidfindlast(int&pl,intp2,intfangl,intfang2)假女.:遇到弹簧、那么须要找到最终的落点Inta=pl,b=2;pl+=fangl*spring(a(b;p2*=fang2spri11g(ab);if(pl<=O)P11;return;if(l>11)pl=11;return;if(2<=O)(P2=l;return;)if(p2>m)p2=m;return;)if(spring(pllp2=0)return;elsefindlast(pl,p2,fa11gl,fang2);intsearch(inta,intb)(if(a=e11d.x&&b=end.y)return1;elseinttag=pp(front)/l;/tag无其他还以,只是pp(front*l须要用许多次.为了简便,下同lf(b-l>O&&mapab-l=O)if(spring(八)(b-l)>O)/推阍是否有弹费.下同intpl=a,p2=b-l;findlast(pl,p2,O,l);/找到必终的落点,最终的落点就是要存在队列里的点.0.-1,表示此时搜寻方向,下同if(mapplp2=0)(prear,x=pl;rear.y=p2;pp(rear*+j=tag;mapplp2=l;)else(prear.x=a;prear.y=bl;pprear*+j=tag;map(ab-l=l;)if(a-l>0&&map(a-lb»0)if(spring(alMb>O(intpl=a-l,p2=b;fidlast(pl,p2,-l,0);if(mapplp2=0)(p(rear.x=pl;rear.y=p2;pp(rear*+)=tag;mapplp2三l;)else(prear.x=a-l;rear.y=b;pp(rear+=tag;map(a-l)b三l;)if(a+l<=n&&mapa+lb)=O)if(spring(a*l(b>O)(intpl=a+l,p2=b;findlast(pl,p2,l,O);if(mapplp2=0)(prear,x=pl;rear.y=p2;PPrear+卜tag;mapplp2=l;+rear;)elseprear.x=a+l;p(rear.y三b;pp(rear+)=tag;map(a+l)b)=l;)lf(b+l<=m&&map(a(b+l=O)if(spring(八)(b÷l>O)(intpl=a,p2=b+l;fidlast(pl,p2zO,l);if(mapplp2=O)(prear.×=pl;(rear.y=p2;pp(rear*+=tag;mapplp2=l;else(prear.x=a;prear.y=b+l;PPrear+卜tag;mapab÷l=l;)returnO;intmain()(intk,i,j;WhlIe(SSnfr%d%d%d",&n,&m,&k)I=EoF)for(i=l;i<=n;+i)(forG=l;j<=m;4+j)(SPringIim卜O;mapij=O;)While伙一)(5canf("%d%d",&i,&j);/«i入弹簧坐标SCanfrW&prlng口皿)力/输入该弹簧能ftfront=0;rear=l;SCanfc'%d%d%dXd",&pfronU.x&pfronUM&end.x,&end.Y)W/输入起点和终点,即是你的位置和宝葫芦的位置ppfront=0;while(front<rear)lf(search(pfront.×,pfront.y)break;front*+;)if(front=rear)printf("impossiblen");elseprintf("%dn",ppfront);)return0;

    注意事项

    本文(bfs解决宝葫芦问题——解题报告 广搜(bfs)算法.docx)为本站会员(王**)主动上传,优知文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知优知文库(点击联系客服),我们立即给予删除!

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




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2023 yzwku网站版权所有

    经营许可证编号:宁ICP备2022001189号-2

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

    收起
    展开