5.2 maze

题目链接

maze

题目思路

优先队列排列时间,bfs找最短时间

代码实现

#include<bits/stdc++.h>
using namespace std;
const int Max=301;
int n,m,q,sx,sy,ex,ey;
int mp[Max][Max],vis[Max][Max];
struct Node{
    int x,y,tm;
    bool operator < (const Node b) const{
        return tm>b.tm;
    }
};
int dr[4][2]={{1,0},{-1,0},{0,1},{0,-1}};
int mark[Max][Max];
vector<Node> send[Max][Max];
//预处理
bool judge(Node a)
{
    if(vis[a.x][a.y])    return false;
    if(!mp[a.x][a.y])    return false;
    return true;
}

int bfs()
{
    priority_queue<Node> qu;
    qu.push(Node{sx,sy,0});
    vis[sx][sy]=1;
    while(!qu.empty())
    {
        Node tp=qu.top();
        qu.pop();
        if(tp.x==ex&&tp.y==ey)
            return tp.tm;
        if(mark[tp.x][tp.y])
        {
            for(int i=send[tp.x][tp.y].size()-1;i>=0;i--)
            {
                Node nx=send[tp.x][tp.y][i];
                if(judge(nx))
                {
                    nx.tm=tp.tm+3;
                    qu.push(nx);
                }
            }
        }
        for(int i=0;i<4;i++)
        {
            Node nx{tp.x+dr[i][0],tp.y+dr[i][1],tp.tm+1};
            if(judge(nx))
            {
                qu.push(nx);
                vis[nx.x][nx.y]=1;
            }
        }
    }
    return -1;
}
int main()
{
    while(cin>>n>>m>>q)
    {
        char c;
        memset(mp,0,sizeof(mp));
        memset(vis,0,sizeof(vis));
        memset(mark,0,sizeof(mark));
        memset(send,0,sizeof(send));
        for(int i=1;i<=n;i++)
            for(int j=1;j<=m;j++)
            {
                cin>>c;
                if(c=='.')    mp[i][j]=1;
                if(c=='S')    sx=i,sy=j,mp[i][j]=1;
                if(c=='T')    ex=i,ey=j,mp[i][j]=1;
            }
        int x1,y1,x2,y2;    
        for(int i=0;i<q;i++)
        {
            cin>>x1>>y1;
            x1++,y1++;
            mark[x1][y1]=1;
            cin>>x2>>y2;
            x2++,y2++;
            send[x1][y1].push_back(Node{x2,y2});
        }
        cout<<bfs()<<endl;
    }
    return 0;
} 
全部评论

相关推荐

挥毫自在:想白嫖你呢
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 你的mentor是什么样的人? #
3795次浏览 27人参与
# 你觉得mentor喜欢什么样的实习生 #
10187次浏览 283人参与
# 未岚大陆求职进展汇总 #
23798次浏览 111人参与
# 帮我看看,领导说这话什么意思? #
6032次浏览 25人参与
# 没有家庭托举的我是怎么找工作的 #
12230次浏览 156人参与
# 怎么给家人解释你的工作? #
1337次浏览 16人参与
# 平安产险科技校招 #
2400次浏览 0人参与
# 求职低谷期你是怎么度过的 #
5169次浏览 91人参与
# 26届秋招公司红黑榜 #
11674次浏览 40人参与
# 从哪些方向判断这个offer值不值得去? #
6497次浏览 91人参与
# 同bg的你秋招战况如何? #
158806次浏览 927人参与
# 度小满求职进展汇总 #
10058次浏览 49人参与
# 实习必须要去大厂吗? #
146606次浏览 1541人参与
# 校招泡的最久的公司是哪家? #
4431次浏览 20人参与
# 你有哪些缓解焦虑的方法? #
37172次浏览 835人参与
# 面试紧张时你会有什么表现? #
1687次浏览 20人参与
# 你喜欢工作还是上学 #
77566次浏览 860人参与
# 入职第一天,你准备什么时候下班 #
85471次浏览 467人参与
# 秋招想进国企该如何准备 #
97703次浏览 487人参与
# 简历无回复,你会继续海投还是优化再投? #
103577次浏览 819人参与
# 机械人的工作环境真的很差吗 #
24999次浏览 119人参与
# 独居后,你的生活是更好了还是更差了? #
28125次浏览 263人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务