洛谷P1238 走迷宫——dfs

该文章描述了一个编程挑战,涉及到在一个m×n的迷宫中寻找从起点到终点的所有可行路径。迷宫由1和0表示,1代表可通行,0代表障碍。使用深度优先搜索(DFS)算法,按照特定的移动顺序(左上右下)找出所有不包含重复点的路径。如果找不到任何路径,则输出-1。给定了输入输出样例和AC代码示例,代码使用C++实现。
摘要由CSDN通过智能技术生成

题目描述

有一个 m×n 格的迷宫(表示有 m 行、n 列),其中有可走的也有不可走的,如果用 1 表示可以走,0 表示不可以走,文件读入这 m×n 个数据和起始点、结束点(起始点和结束点都是用两个数据来描述的,分别表示这个点的行号和列号)。现在要你编程找出所有可行的道路,要求所走的路中没有重复的点,走时只能是上下左右四个方向。如果一条路都不可行,则输出相应信息(用 −1 表示无路)。

优先顺序:左上右下。数据保证随机生成。

输入格式

第一行是两个数 (1<m,n<15),接下来是 m 行 n 列由 1 和 0 组成的数据,最后两行是起始点和结束点。

输出格式

所有可行的路径,描述一个点时用 (x,y) 的形式,除开始点外,其他的都要用 -> 表示方向。

如果没有一条可行的路则输出 −1。

输入输出样例

输入 #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,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)

AC代码

#include<iostream>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
typedef long long ll;
int n ,m, mp[23][23],stx,sty,enx,eny;
int vis[23][23],txy[]={0,-1,0,1,0},ans;
int a[213],b[213];
void dfs(int x , int y,int pos)
{
    if( x == enx && y == eny)
    {
        ans++;
        cout<<"("<<a[0]<<","<<b[0]<<")";
        for(int i=1;i<=pos;++i) cout<<"->("<<a[i]<<","<<b[i]<<")";
        cout<<endl;
        return;
    }
    for(int i=0;i<=3;++i)
    {
        int tx = x + txy[i];
        int ty = y + txy[i+1];
        if( tx<1 || tx>n || ty<1 || ty>m || vis[tx][ty] || !mp[tx][ty] ) continue;  //vis为1不能走,mp为0不能走

        a[pos + 1] = tx; b[pos + 1 ] = ty;
        vis[tx][ty] = 1;
        dfs(tx,ty,pos+1);
        vis[tx][ty] = 0 ;

    }
}
int main()
{
    scanf("%d %d",&n,&m);
    for(int i=1;i<=n;++i)
        for(int j=1;j<=m;++j)
        scanf("%d",&mp[i][j]);
    scanf("%d %d %d %d",&stx,&sty,&enx,&eny);
    vis[stx][sty] = 1;
    a[0] = stx;b[0] = sty;
    dfs(stx,sty,0);
    if(!ans || stx==sty==0) cout<<-1;
    return 0 ;
}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值