ImageVerifierCode 换一换
格式:DOCX , 页数:5 ,大小:15.09KB ,
资源ID:14562307      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/14562307.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(bfs解决宝葫芦问题解题报告+广搜(bfs)算法Word格式文档下载.docx)为本站会员(b****2)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

bfs解决宝葫芦问题解题报告+广搜(bfs)算法Word格式文档下载.docx

1、=m-1),p是弹簧的能量。在下面的两行里,分别是你和宝葫芦的坐标。此外,你在空中经过的弹簧对你没有任何影响。已知你、宝葫芦和弹簧的初始位置都不同。x坐标轴的范围是1到n,y坐标轴的范围是1到m。有多组测试用例。输出:最少的步数,或者impossible题目来源:bit网络教室解题思路:首先明确这是一个搜索问题,并且不需要记录路径,那么就不需要要用深搜(dfs),并且深搜需要搜索完所有的点才能却确定出最小的解,这个代价是很大的,所以应该选择广搜(bfs)。在搜索的时候,建立队列,把人的起点都放在队列的开始,然后从它开始搜索,搜都的点放在队列里,然后从队列里取值搜索,直到到搜到宝葫芦为止,最少的

2、步数就是搜索的层数,若果搜索完队列里的所有元素,还没有找到宝葫芦,那么就是impossible。需要注意的细节:1)当你跳到弹簧的时候,一定要把此次弹簧跳的终点存在队列里,而不是把弹簧的坐标存在队列里面。2)弹簧可能被用多次,跳过之后不要删附上代码,仅供参考:*/#includemath.h#define N 105int n,m,flag;int front,rear;int springNN,mapNN,ppN*N;/spring弹簧,map标记是否搜过,0-还没碰过,1-看到了,2-搜过了;pp该点至少跳几次才到struct pointint x;int y;struct point e

3、nd,pN*N;void findlast(int &p1,int &p2,int fang1,int fang2)/如果遇到弹簧,那么需要找到最终的落点int a=p1,b=p2;p1+=fang1*springab;p2+=fang2*springab;if(p1n)p1=n;if(p2m)p2=m;if( springp1p2=0 )else findlast(p1,p2,fang1,fang2);int search(int a,int b)if( a=end.x & b=end.y )return 1;elseint tag=ppfront+1;/tag无其他还以,只是ppfront

4、+1需要用很多次,为了简便,下同if(b-10&mapab-1=0)if(springab-10)/判断是否有弹簧,下同int p1=a,p2=b-1;findlast(p1,p2,0,-1);/找到最终的落点,最终的落点就是要存在队列里的点,0,-1,表示此时搜索方向,下同if(mapp1p2=0)prear.x=p1;prear.y=p2;pprear+=tag;mapp1p2=1;elseprear.x=a;prear.y=b-1;mapab-1=1;if(a-1mapa-1b=0)if(springa-1b0)int p1=a-1,p2=b;findlast(p1,p2,-1,0);p

5、rear.x=a-1;prear.y=b;mapa-1b=1;if(a+1int p1=a+1,p2=b;findlast(p1,p2,1,0);+rear;prear.x=a+1;mapa+1b=1;if(b+1int p1=a,p2=b+1;findlast(p1,p2,0,1);prear.y=b+1;mapab+1=1;return 0;int main()int k,i,j;while(scanf(%d%d%d,&n,&m,&k)!=EOF)for(i=1;i=n;+i)for(j=1;j=m;+j)springij=0;mapij=0;while(k-)scanf(%d%di,&j);/输入弹簧坐标%dspringij);/输入该弹簧能量front=0;rear=1;scanf(%d%d%d%dpfront.x,&pfront.y,&end.x,&end.y);/输入起点和终点,即是你的位置和宝葫芦的位置ppfront=0;while(frontrear)if(search(pfront.x,pfront.y)break;front+;if(front=rear)printf(impossiblen);else%dn,ppfront);return 0;

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1