




全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
/*宝葫芦问题解题报告题目:宝葫芦被放在一个城堡里。城堡由n*m个方格组成,你只能从当前所在的方格跳到相邻的4个方格里,而且不能跳出城堡的范围。城堡中某些方格里有弹簧,每个弹簧具有一个特定能量p,不同弹簧的p值不一定相同。如果你跳到一个有弹簧的方格,就会立刻沿着原来运动的方向继续跳p格,如果跳到的方格里又有弹簧,就马上继续跳,直到跳到一个空的方格或者被墙挡住无法继续前进为止。你能否尽快找到宝葫芦吗?输入:第一行有两个整数,n和m(3=n,m=100),分别是城堡的行数和列数。其后是一个非负整数k,表示弹簧的个数。在接下来的k行里,每行有三个正数x, y, p,以空格隔开,其中x和y是弹簧的坐标(2=x=n-1, 2=y=m-1),p是弹簧的能量。在下面的两行里,分别是你和宝葫芦的坐标。此外,你在空中经过的弹簧对你没有任何影响。已知你、宝葫芦和弹簧的初始位置都不同。x坐标轴的范围是1到n,y坐标轴的范围是1到m。有多组测试用例。输出:最少的步数,或者impossible题目来源:bit网络教室解题思路:首先明确这是一个搜索问题,并且不需要记录路径,那么就不需要要用深搜(dfs),并且深搜需要搜索完所有的点才能却确定出最小的解,这个代价是很大的,所以应该选择广搜(bfs)。在搜索的时候,建立队列,把人的起点都放在队列的开始,然后从它开始搜索,搜都的点放在队列里,然后从队列里取值搜索,直到到搜到宝葫芦为止,最少的步数就是搜索的层数,若果搜索完队列里的所有元素,还没有找到宝葫芦,那么就是impossible。需要注意的细节:1)当你跳到弹簧的时候,一定要把此次弹簧跳的终点存在队列里,而不是把弹簧的坐标存在队列里面。2)弹簧可能被用多次,跳过之后不要删附上代码,仅供参考:*/#include#include#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 end,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;return;if(p2m)p2=m;return;if( springp1p2=0 )return;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+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;pprear+=tag;mapab-1=1;if(a-10&mapa-1b=0)if(springa-1b0)int p1=a-1,p2=b;findlast(p1,p2,-1,0);if(mapp1p2=0)prear.x=p1;prear.y=p2;pprear+=tag;mapp1p2=1;elseprear.x=a-1;prear.y=b;pprear+=tag;mapa-1b=1;if(a+10)int p1=a+1,p2=b;findlast(p1,p2,1,0);if(mapp1p2=0)prear.x=p1;prear.y=p2;pprear+=tag;mapp1p2=1;+rear;elseprear.x=a+1;prear.y=b;pprear+=tag;mapa+1b=1;if(b+10)int p1=a,p2=b+1;findlast(p1,p2,0,1);if(mapp1p2=0)prear.x=p1;prear.y=p2;pprear+=tag;mapp1p2=1;elseprear.x=a;prear.y=b+1;pprear+=tag;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%d,&i,&j);/输入弹簧坐标scanf(%d,&springij);/输入该弹簧能量front=0;rear=1;scanf(%d%d%d%d,&pfront.x,&pfront.y,&end.x,&end.y);/输入起点和终点,即是你的位置和宝葫芦的位置ppfront=0;while(f
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年家电行业智能家电发展前景报告
- 商场安保消防安全培训课件
- 2025年量子科技行业应用前景与技术突破研究报告
- 2025年环保科技行业环保科技应用前景研究报告
- 商场保安安全培训总结课件
- 宁波市2025年浙江宁波卫生职业技术学院招聘工作人员4名笔试历年参考题库附带答案详解
- 四川省2025年上半年四川省广安市“小平故里英才”引进急需紧缺专业人才笔试历年参考题库附带答案详解
- 南京市2025江苏南京科技职业学院招聘工作人员7人(第二批)笔试历年参考题库附带答案详解
- 2025湖南省水务规划设计院有限公司招聘25人笔试参考题库附带答案详解
- 2025河南农业投资集团子公司招聘13人笔试参考题库附带答案详解
- 边坡工程第3章 边坡工程地质勘察
- 索思医疗卓越产品系列穿戴式动态心电监测产品
- 全国医药行业特有职业技能竞赛中药调剂员赛项备赛试题库(含答案)
- 中建基础设施公司“主要领导讲质量”
- 房屋交易诚意金合同范本模板
- 《毛泽东思想的形成与发展》参考课件3
- GB/T 4706.95-2024家用和类似用途电器的安全第95部分:商用电动抽油烟机的特殊要求
- JTG 3362-2018公路钢筋混凝土及预应力混凝土桥涵设计规范
- 脑梗死知识讲解模板
- 女性中医保健智慧树知到期末考试答案章节答案2024年暨南大学
- (正式版)JTT 1497-2024 公路桥梁塔柱施工平台及通道安全技术要求
评论
0/150
提交评论