DFS(深搜)例题 解题与心得
来源:互联网 发布:域名查询接口api 编辑:程序博客网 时间:2024/06/06 15:42
【问题描述】
有一个m*n格的迷宫(表示有m行、n列),其中有可走的也有不可走的,如果用1表示可以走,0表示不可以走,文件读入这m*n个数据和起始点、结束点(起始点和结束点都是用两个数据来描述的,分别表示这个点的行号和列号)。现在要你分别编程4个程序解决以下4个问题。
问题1:找出所有可行的道路,要求所走的路中没有重复的点,走时只能是上下左右四个方向。如果一条路都不可行,则输出相应信息(用-l表示无路)。
问题2:求最少需要几步可以从起始点到达结束点。
问题3:求从起始点到达结束点的一条最短路径。
问题4:求从起始点到达结束点的所有最短路径。
【输入】
第一行是两个数m,n(1<m,n<15),接下来是m行n列由1和0组成的数据,最后两行是起始点和结束点。
【输出】
问题1:所有可行的路径,描述一个点时用(x,y)的形式,除开始点外,其他的都要用“一>”表示方向。如果没有一条可行的路则输出-1。
……
【样例】
5 6
1 0 0 1 0 1
1 1 1 1 1 1
0 0 1 1 1 0
1 1 1 1 1 0
1 1 1 0 1 1
1 1
5 6
【输出样例】
(1,1)->(2,1)->(2,2)->(2,3)->(2,4)->(2,5)->(3,5)->(3,4)->(3,3)->(4,3)->(4,4)->(4,5)->(5,5)->(5,6)
(1,1)->(2,1)->(2,2)->(2,3)->(2,4)->(2,5)->(3,5)->(3,4)->(4,4)->(4,5)->(5,5)->(5,6)
(1,1)->(2,1)->(2,2)->(2,3)->(2,4)->(2,5)->(3,5)->(4,5)->(5,5)->(5,6)
(1,1)->(2,1)->(2,2)->(2,3)->(2,4)->(3,4)->(3,3)->(4,3)->(4,4)->(4,5)->(5,5)->(5,6)
(1,1)->(2,1)->(2,2)->(2,3)->(2,4)->(3,4)->(3,5)->(4,5)->(5,5)->(5,6)
(1,1)->(2,1)->(2,2)->(2,3)->(2,4)->(3,4)->(4,4)->(4,5)->(5,5)->(5,6)
(1,1)->(2,1)->(2,2)->(2,3)->(3,3)->(3,4)->(2,4)->(2,5)->(3,5)->(4,5)->(5,5)->(5,6)
(1,1)->(2,1)->(2,2)->(2,3)->(3,3)->(3,4)->(3,5)->(4,5)->(5,5)->(5,6)
(1,1)->(2,1)->(2,2)->(2,3)->(3,3)->(3,4)->(4,4)->(4,5)->(5,5)->(5,6)
(1,1)->(2,1)->(2,2)->(2,3)->(3,3)->(4,3)->(4,4)->(3,4)->(2,4)->(2,5)->(3,5)->(4,5)->(5,5)->(5,6)
(1,1)->(2,1)->(2,2)->(2,3)->(3,3)->(4,3)->(4,4)->(3,4)->(3,5)->(4,5)->(5,5)->(5,6)
(1,1)->(2,1)->(2,2)->(2,3)->(3,3)->(4,3)->(4,4)->(4,5)->(5,5)->(5,6)#include <iostream>//走迷宫using namespace std;intm,n,p[15][15]={0},bx,by,ex,ey;intdx[5]={0,1,0,-1,0},//表示上下dy[5]={0,0,1,0,-1};//表示左右int way[225][3]={0};//保存路径bool set[15][15];bool flag;int minStep=1000;int minWay[255][3];bool check(int tx,int ty){if(p[tx][ty]!=1) return false;//碰壁if(tx>m || tx<1 || ty<1 ||ty>n) return false;//越界return true;}void search(int dep,int x,int y){int tx,ty;//if(dep>m*n) return;if( x==ex && y==ey ){cout<<'('<<bx<<","<<by<<')';for(int i=1;i<dep;i++)cout<<"->"<<'('<<way[i][1]<<","<<way[i][2]<<')';cout<<endl<<endl;flag=true;return;}else{for(int i=1;i<=4;i++){tx=dx[i]+x;ty=dy[i]+y;if( check(tx,ty) && !set[tx][ty] ) {way[dep][1]=tx;way[dep][2]=ty;set[tx][ty]=true;search(dep+1,tx,ty);set[tx][ty]=false;}}}}int main(){cin>>m>>n;for(int i=1;i<=m;i++)for(int j=1;j<=n;j++)cin>>p[i][j];cin>>bx>>by;cin>>ex>>ey;search(1,bx,by);if(!flag) cout<<"-1"<<endl;return 0;}
- DFS(深搜)例题 解题与心得
- 【算法笔记】动态规划,三个例题(解题思路与C++代码)
- dfs 例题(寻找最大距离)
- hdu1198解题报告(dfs)
- hdu1224解题报告(dfs)
- poj1154解题报告(dfs)
- leetcode -- 解题总结--DP与DFS, 递归
- dfs算法经典例题
- dfs(简单例题)
- NYOJ 119 士兵杀敌(三)[RMQ例题]【解题报告】
- uva 1103 紫书例题6-13(dfs)
- 北大 acm 3083解题报告--dfs与bfs的运用
- 错位排列心得及例题
- 区间DP心得及例题
- MCS_ACM DFS解题报告
- DFS 1253 解题报告
- ac自动机(基本解析与例题)
- BalalaPower个人解题心得
- ajax实现评论
- 面向程序员的数据库访问性能优化法则
- CCS教程
- 使用SWIG扩展ruby性能
- Metro C++ 初体验 第一周
- DFS(深搜)例题 解题与心得
- error C2660: 'new' : function does not take 3 parameters
- EXTJS类库解析
- C中对字符串和指针的理解
- 程序员基本功:CSS基础知识
- iBatis缓存的使用方法及解释
- linux中的软件也遵循普通的软件规则
- 编译Linphone 需要的软件包
- static_cast 和 reinterpret_cast