loj 1377 (bfs)
题目链接:http://lightoj.com/volume_showproblem.php?problem=1377
思路:这道题只要处理好遇到"*"这种情况就可以搞定了。我们可以用一个vector向量来记录所有的“*”,然后用一个3维数组来判重,并且对于每个状态都加一个标记,判断是否需要立刻转移,值得注意的是转移过后,vector应该立刻清空。
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
#include <queue>
using namespace std; const int MAXN = ( + );
const int inf = ( << );
int n,m,ans;
char map[MAXN][MAXN];
vector<pair<int, int> >vet; struct Node{
int x, y, step, pre;
bool operator < (const Node &p ) const {
return p.step < step;
}
}st; bool mark[MAXN][MAXN][];
int dir[][]={{,-},{,},{-,},{,}}; void bfs()
{
memset(mark, false, sizeof(mark));
priority_queue<Node >que;
que.push(st);
mark[st.x][st.y][]=true;
while(!que.empty()){
Node q, p = que.top();
que.pop();
if(map[p.x][p.y] == 'D'){
ans = p.step;
return ;
}
if(map[p.x][p.y] == '*'){
bool flag = false;
for(int i = ; i < (int)vet.size(); i++){
pair<int, int>pp = vet[i];
if(pp.first == p.x&&pp.second == p.y){
flag = true;
continue;
}
if(!mark[pp.first][pp.second][]){
mark[pp.first][pp.second][] = true;
Node tmp;
tmp.x = pp.first, tmp.y = pp.second, tmp.step = p.step + , tmp.pre = ;
que.push(tmp);
}
}
vet.clear();
if(flag)vet.push_back(make_pair(p.x,p.y));
if(p.pre == )continue;
}
for(int i = ; i < ; i++){
q.x = p.x + dir[i][];
q.y = p.y + dir[i][];
if(map[q.x][q.y] == '#')continue;
if(!mark[q.x][q.y][]){
mark[q.x][q.y][] = true;
q.step = p.step + ;
q.pre = ;
que.push(q);
}
}
}
} int main()
{
int _case,t=;
scanf("%d",&_case);
while(_case--){
vet.clear();
scanf("%d%d",&n,&m);
for(int i=; i<=n; i++){
scanf("%s", map[i] + );
for(int j=; j<=m; j++){
if(map[i][j] == 'P'){
st.x = i, st.y = j, st.step = , st.pre = ;
}else if(map[i][j] == '*') {
vet.push_back(make_pair(i,j));
}
}
}
ans = inf;
bfs();
printf("Case %d: ", t++);
if(ans == inf){
puts("impossible");
}else
printf("%d\n",ans);
}
return ;
}
loj 1377 (bfs)的更多相关文章
- loj 1185(bfs)
题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=26898 思路:我们可以给定有直接边相连的两点的距离为1,那么就是求 ...
- loj 1165(bfs+康托展开)
题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=26879 思路:题目意思很简单,就是通过一些位置的交换,最后变成有序 ...
- loj 1055(bfs)
题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=26772 思路:注意判重就行,开个6维数组记录3个robots的位置 ...
- loj 1426(dfs + bfs)
题目链接:http://lightoj.com/volume_showproblem.php?problem=1426 思路:首先我们预处理出每一个"*"在某一方向上最终能到达的位 ...
- loj 1046(bfs)
题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=26766 思路:由于数据不是很大,我们可以枚举骑士最后聚集的位置,然 ...
- LOJ 3057 「HNOI2019」校园旅行——BFS+图等价转化
题目:https://loj.ac/problem/3057 想令 b[ i ][ j ] 表示两点是否可行,从可行的点对扩展.但不知道顺序,所以写了卡时间做数次 m2 迭代的算法,就是每次遍历所有不 ...
- 「LOJ#6121」「网络流 24 题」孤岛营救问题(BFS
题目描述 1944 年,特种兵麦克接到国防部的命令,要求立即赶赴太平洋上的一个孤岛,营救被敌军俘虏的大兵瑞恩.瑞恩被关押在一个迷宫里,迷宫地形复杂,但幸好麦克得到了迷宫的地形图.迷宫的外形是一个长方形 ...
- LOJ #2877. 「JOISC 2014 Day2」交朋友 并查集+BFS
这种图论问题都挺考验小思维的. 首先,我们把从 $x$ 连出去两条边的都合并了. 然后再去合并从 $x$ 连出去一条原有边与一条新边的情况. 第一种情况直接枚举就行,第二种情况来一个多源 bfs 即可 ...
- LOJ #2876. 「JOISC 2014 Day2」水壶 BFS+最小生成树+倍增LCA
非常好的一道图论问题. 显然,我们要求城市间的最小生成树,然后查询路径最大值. 然后我们有一个非常神的处理方法:进行多源 BFS,处理出每一个城市的管辖范围. 显然,如果两个城市的管辖范围没有交集的话 ...
随机推荐
- 《Java多线程核心技术》读书摘要
Chapter1: 进程是操作系统管理的基本单元,线程是CPU调到的基本单元. 调用myThread.run()方法,JVM不会生成新的线程,myThread.start()方法调用两次JVM会报错. ...
- 16~25.spring+hibernate简单实例 .连接数据库并进行增删改查
1.概念 Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQ ...
- 8.SpringMVC参数传递
页面参数传递到controller, 可被同名(与页面标签上的name名对应)的参数接收,用request设值,页面再取出来. 注意乱码解决办法: ①如果是get提交,则在tomcat的server. ...
- Maven 3.3.3 Win10环境下的使用实例(下)
这一篇文章将介绍如何在 Eclipse 中使用 Maven. 我们以 Eclipse Java EE 版本为例,首先要对 IDE 进行一些设置: JDK 环境 Maven 的本地安装路径 Maven ...
- Effective C++ -----条款52:写了placement new 也要写 placement delete
当你写一个placement operator new ,请确定也写出了对应的placement operator delete.如果没有这样做,你的程序可能会发生隐微而时断时续的内存泄漏. 当你声明 ...
- IE的if条件Hack(兼容性)
1. 〈!--[if !IE]〉〈!--〉 除IE外都可识别 〈!--〈![endif]--〉 2. 〈!--[if IE]〉 所有的IE可识别〈![endif]--〉 3. 〈!--[if IE 5 ...
- 【leetcode】Combination Sum III(middle)
Find all possible combinations of k numbers that add up to a number n, given that only numbers from ...
- 【python】classmethod & staticmethod 区别
来源:http://blog.csdn.net/carolzhang8406/article/details/6856817 其他参考: http://blog.csdn.net/lovingprin ...
- python安装paramiko模块
一.简介 paramiko是用python语言写的一个模块,遵循SSH2协议,支持以加密和认证的方式,进行远程服务器的连接. 由于使用的是python这样的能够跨平台运行的语言,所以所有python支 ...
- selinux
root@lujie ~]# vim /etc/sysconfig/selinux # This file controls the state of SELinux on the system. # ...