题解:洛谷 P2199 最后的迷宫

题目https://www.luogu.com.cn/problem/P2199

显然,数据最大 ,数组我们开不下,动态开数组。

对于每一个查询,从起点开始,走一步判断是否能看到火焰杯。

如果已经没法走了,直接拆墙,输出 Poor Harry。

实现

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int n,m,Bx,By,Ex,Ey,xux[8][3]={{-1,-1},{-1,0},{-1,1},{0,-1},{0,1},{1,-1},{1,0},{1,1}},xyx[5][3]={{-1,0},{1,0},{0,1},{0,-1}};
vector<char>a[16385];
bool check(int dx,int dy){
    for(int i=0;i<8;i++){
        int af=dx,bt=dy;
        while(true){
            if(af<1||bt<1||af>n||bt>m||a[af][bt]=='X'){
                break;
            }
            if(af==Ex&&bt==Ey){
                return true;
            }
            af+=xux[i][0],bt+=xux[i][1];
        }
    }
    return false;
}
int bfs(int Bx,int By){
    vector<int>dis[n+5];
    vector<bool>vis[n+5];
    for(int i=1;i<=n+3;i++){
        for(int j=0;j<=m+1;j++){
            dis[i].push_back(0);
            vis[i].push_back(false);
        }
    }
    queue<pair<int,int>>q;
    q.push({Bx,By});
    vis[Bx][By]=true;
    while(q.size()){
        auto p=q.front();
        q.pop();
        if(check(p.first,p.second)){
            return dis[p.first][p.second];
        }
        for(int i=0;i<4;i++){
            int dx=p.first+xyx[i][0],dy=p.second+xyx[i][1];
            if(dx&&dy&&dx<=n&&dy<=m&&!vis[dx][dy]&&a[dx][dy]!='X'){
                dis[dx][dy]=dis[p.first][p.second]+1,vis[dx][dy]=true;
                q.push({dx,dy});
            }
        }
    }
    return -1;
}
int main(){
    ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    cin>>n>>m;
    for(int i=1;i<=n;i++){
        a[i].push_back(0);
        for(int j=1;j<=m;j++){
            char x;
            cin>>x;
            a[i].push_back(x);
        }
    }
    while(true){
        cin>>Ex>>Ey>>Bx>>By;
        if(!Bx||!By||!Ex||!Ey){
            return 0;
        }
        int tmp=bfs(Bx,By);
        cout<<(tmp==-1?"Poor Harry":to_string(tmp))<<'\n';
    }
    return 0;
}

P.S.:呃......我写的时候把方向写错了。

解法2

,可以考虑用一维数组进行存储。

我们进行"降维打击",从二维坐标转化为一维坐标,比如说有一个网格:

|-------------------------------------|-------------------------------------|-------------------------------------|-------------------------------------|
| | | | |
| | | | |
| | | | |
| | | | |

将其转化为一维坐标:

|----------------------------------|----------------------------------|----------------------------------|----------------------------------|
| | | | |
| | | | |
| | | | |
| | | | |

具体来说,对于一个二维坐标 ,其一维坐标为

其他的地方就跟二维的写法一样了。

实现

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int n,m,Bx,By,Ex,Ey,dis[17005],xux[8][3]={{-1,-1},{-1,0},{-1,1},{0,-1},{0,1},{1,-1},{1,0},{1,1}},xyx[5][3]={{-1,0},{1,0},{0,1},{0,-1}};
char a[17005];
bool vis[17005];
int XY(int dx,int dy){
    return (dx-1)*m+dy;
}
bool check(int dx,int dy){
    for(int i=0;i<8;i++){
        int af=dx,bt=dy;
        while(true){
            if(af<1||bt<1||af>n||bt>m||a[XY(af,bt)]=='X'){
                break;
            }
            if(af==Ex&&bt==Ey){
                return true;
            }
            af+=xux[i][0],bt+=xux[i][1];
        }
    }
    return false;
}
int bfs(int Bx,int By){
    fill(vis,vis+n*m+5,false);
    queue<pair<int,int> >q;
    q.push({Bx,By});
    vis[XY(Bx,By)]=true,dis[XY(Bx,By)]=0;
    while(q.size()){
        auto p=q.front();
        q.pop();
        if(check(p.first,p.second)){
            return dis[XY(p.first,p.second)];
        }
        for(int i=0;i<4;i++){
            int dx=p.first+xyx[i][0],dy=p.second+xyx[i][1];
            if(dx&&dy&&dx<=n&&dy<=m&&!vis[XY(dx,dy)]&&a[XY(dx,dy)]!='X'){
                dis[XY(dx,dy)]=dis[XY(p.first,p.second)]+1,vis[XY(dx,dy)]=true;
                q.push({dx,dy});
            }
        }
    }
    return -1;
}
int main(){
    ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    cin>>n>>m;
    for(int i=1;i<=n;i++){
        for(int j=1;j<=m;j++){
            cin>>a[XY(i,j)];
        }
    }
    while(true){
        cin>>Ex>>Ey>>Bx>>By;
        if(!Bx||!By||!Ex||!Ey){
            return 0;
        }
        int tmp=bfs(Bx,By);
        cout<<(tmp==-1?"Poor Harry":to_string(tmp))<<'\n';
    }
    return 0;
}
相关推荐
CoovallyAIHub12 小时前
中科大DSAI Lab团队多篇论文入选ICCV 2025,推动三维视觉与泛化感知技术突破
深度学习·算法·计算机视觉
NAGNIP13 小时前
Serverless 架构下的大模型框架落地实践
算法·架构
moonlifesudo13 小时前
半开区间和开区间的两个二分模版
算法
moonlifesudo13 小时前
300:最长递增子序列
算法
CoovallyAIHub18 小时前
港大&字节重磅发布DanceGRPO:突破视觉生成RLHF瓶颈,多项任务性能提升超180%!
深度学习·算法·计算机视觉
CoovallyAIHub19 小时前
英伟达ViPE重磅发布!解决3D感知难题,SLAM+深度学习完美融合(附带数据集下载地址)
深度学习·算法·计算机视觉
聚客AI1 天前
🙋‍♀️Transformer训练与推理全流程:从输入处理到输出生成
人工智能·算法·llm
大怪v2 天前
前端:人工智能?我也会啊!来个花活,😎😎😎“自动驾驶”整起!
前端·javascript·算法
惯导马工2 天前
【论文导读】ORB-SLAM3:An Accurate Open-Source Library for Visual, Visual-Inertial and
深度学习·算法
骑自行车的码农2 天前
【React用到的一些算法】游标和栈
算法·react.js