简单的题解(深搜)包过
2025-09-05 19:29:39
发布于:浙江
15阅读
0回复
0点赞
深搜可以不用打表
无注释,自行按照深搜解法理解
#include<bits/stdc++.h>
using namespace std;
int mp[20][20];
int vis[20][20];
int dir[4][2]={0,-1,-1,0,0,1,1,0};
int sx,sy;
int ex,ey;
int path[400][2];
int pathsize;
int m,n;
int flag;
void dfs(int x,int y) {
    if (x==ex&&y==ey) {
        flag=1;
        cout<<"("<<sx<<","<<sy<<")";
        for(int i=0;i<pathsize;i++)cout<<"->("<<path[i][0]<<","<<path[i][1]<<")";
        cout<<endl;
        return;
    }
    for(int i=0;i<4;i++) {
        int nx=x+dir[i][0];
        int ny=y+dir[i][1];
        if (nx>=1&&nx<=n&&ny>=1&&ny<=m&&mp[nx-1][ny-1]==1&&!vis[nx][ny]){
            vis[nx][ny]=1;
            path[pathsize][0]=nx;
            path[pathsize++][1]=ny;
            dfs(nx,ny);
            pathsize--;
            vis[nx][ny]=0;
        }
    }
}
int main(){
    cin>>n>>m;
    for(int i=0;i<n;i++)for(int j=0;j<m;j++)cin>>mp[i][j];
    cin>>sx>>sy;
    cin>>ex>>ey;
    vis[sx][sy]=1;
    dfs(sx,sy);
    if(!flag)cout<<-1;
    return 0;
}
这里空空如也






有帮助,赞一个