zoukankan      html  css  js  c++  java
  • AcWing 844. 走迷宫

    深搜模板题

    https://www.acwing.com/problem/content/846/

    模拟队列

    #include<bits/stdc++.h>
    using namespace std;
    const int N=110;
    int n,m;
    int g[N][N];  //地图
    int d[N][N];  //到起点的距离
    typedef pair<int,int>PII;
    PII q[N*N];   //pair
    int bfs() {
        int hh=0,tt=0;   //hh 队头   ,tt 队尾
        q[0]= {0,0};
        memset(d,-1,sizeof d);  //初始化
        d[0][0]=0;  //起点到起点的距离为0
        int dx[4]= {-1,0,1,0}, dy[4] = {0,1,0,-1};
        while(hh<=tt) {
            auto t = q[hh++];  //取出队头
            for(int i=0; i<4; i++) {
                int x=t.first+dx[i],y=t.second+dy[i];
                if(x>=0&&x<n&&y>=0&&y<m&&g[x][y]==0&&d[x][y]==-1) {   //为空地不是障碍物,而且没有走过,
                    d[x][y]=d[t.first][t.second]+1;  //标记距离
                    q[++tt]= {x,y};       //在放进去
                }
            }
        }
        return d[n-1][m-1];
    }
    int main() {
        cin>>n>>m;
        for(int i=0; i<n; i++)
            for(int j=0; j<m; j++)
                cin>>g[i][j];
        cout<<bfs()<<endl;
        return 0;
    }

    输出路径

    #include<bits/stdc++.h>
    using namespace std;
    const int N=110;
    int n,m;
    int g[N][N];  //地图
    int d[N][N];  //到起点的距离
    typedef pair<int,int>PII;
    PII q[N*N];//pair
    PII Prev[N][N];    //用来记录x,y 这个点从哪个点过来,并输出路径
    int bfs() {
        int hh=0,tt=0;   //hh 队头   ,tt 队尾
        q[0]= {0,0};
        memset(d,-1,sizeof d);  //初始化
        d[0][0]=0;  //起点到起点的距离为0
        int dx[4]= {-1,0,1,0}, dy[4] = {0,1,0,-1};
        while(hh<=tt) {
            auto t = q[hh++];  //取出队头
            for(int i=0; i<4; i++) {
                int x=t.first+dx[i],y=t.second+dy[i];
                if(x>=0&&x<n&&y>=0&&y<m&&g[x][y]==0&&d[x][y]==-1) {   //为空地不是障碍物,而且没有走过,
                    Prev[x][y]=t;   //记录从哪个个点过来
                    d[x][y]=d[t.first][t.second]+1;  //标记距离
                    q[++tt]= {x,y};       //在放进去
                }
            }
        }
        int x=n-1,y=m-1;
        while(x||y) {
            cout<<x<<" "<<y<<endl;
            auto t=Prev[x][y];
            x=t.first,y=t.second;  //输出路径
        }
        return d[n-1][m-1];
    }
    int main() {
        cin>>n>>m;
        for(int i=0; i<n; i++)
            for(int j=0; j<m; j++)
                cin>>g[i][j];
        cout<<bfs()<<endl;
        return 0;
    }

     应用队列

    #include<bits/stdc++.h>
    using namespace std;
    const int N=110;
    int n,m;
    int g[N][N];  //地图
    int d[N][N];  //到起点的距离
    typedef pair<int,int>PII;
    queue<PII> q;
    int bfs() {
        q.push({0,0});
        memset(d,-1,sizeof d);
        d[0][0]=0;
        int dx[4]= {-1,0,1,0}, dy[4] = {0,1,0,-1};
        while(!q.empty()) {
            auto t=q.front();
            q.pop();
    
            for(int i=0; i<4; i++) {
                int x=t.first+dx[i],y=t.second+dy[i];
                if(x>=0&&x<n&&y>=0&&y<m&&g[x][y]==0&&d[x][y]==-1) {
                    d[x][y]=d[t.first][t.second]+1;
                    q.push({x,y});
                }
            }
        }
        return d[n-1][m-1];
    }
    int main() {
        cin>>n>>m;
        for(int i=0; i<n; i++)
            for(int j=0; j<m; j++)
                cin>>g[i][j];
        cout<<bfs()<<endl;
        return 0;
    }
  • 相关阅读:
    ubuntu16.04安装配置nagios
    springboot+mybatis+springmvc整合实例
    网站性能优化小结和spring整合redis
    mybatis的批量更新实例
    安装webpack和webpack打包(此文转自Henery)
    微信扫描二维码下载软件
    ubuntu16.04设置tomcat自启动
    无意中在sql日志中发现如下内容,
    实现虚拟模式的动态数据加载Windows窗体DataGridView控件 .net 4.5 (一)
    (C#)WinForm窗体间传值
  • 原文地址:https://www.cnblogs.com/QingyuYYYYY/p/11739215.html
Copyright © 2011-2022 走看看