题目链接:http://poj.org/problem?id=2049

解题报告:

网格中的BFS,最主要的是边界问题。

1、这里在左右,上下两个方向上,分别判断墙,和门,细节是,向上有t个墙,for(int j=0;j<t;j++) ya[x][y+1+j]=WALL;   ymax=max(y+t+1,ymax);xmax=max(x+1,xmax);

2、这里采用的是逆向BFS,从dis[1][1]出发,输出dis[tx][ty];

#include <iostream>
#include <queue>
#include <stdio.h>
#include <string.h> using namespace std; #define MAXV 210
#define INF 1<<29
#define min(a,b) (a>b?b:a)
#define max(a,b) (a>b?a:b) #define EMPTY 0
#define DOOR 1
#define WALL INF int xa[MAXV][MAXV]; ///在x方向上添上墙
int ya[MAXV][MAXV]; ///在y方向上添上墙 int dis[MAXV][MAXV]; ///目标答案,dis[i][j]先初始化为无穷,然后置dis[1][1]为0,
///根据x,y方向上的是否有墙,自增,没有墙置+0,有门+1,dis[tx][ty]也就是答案 int dt[][]= {{-,},{,},{,-},{,}}; ///四个方向分别是向上,向下,向左,向右 int xmax,ymax; ///x,y方向上的边界 ///判断是否在图表中
bool pd(int x,int y)
{
if(x> && x<=xmax && y<=ymax && y>) return ;
return ;
} int getvalue(int x,int y,int i)
{
if(i==) return ya[x-][y];
if(i==) return ya[x][y];
if(i==) return xa[x][y-];
return xa[x][y];
} ///逆向广搜
int bfs(int tx,int ty)
{
int i,j,vx,vy,dx,dy,tmp;
queue <int>q; ///初始化
for(i=; i<=ymax; i++)
{
for(j=; j<=xmax; j++)
dis[i][j]=INF;
} dis[][]=;
q.push();
q.push();
while(!q.empty())
{
vx=q.front();
q.pop();
vy=q.front();
q.pop(); for(i=; i<; i++)
{
dx=vx+dt[i][];
dy=vy+dt[i][]; tmp=getvalue(vx,vy,i); ///tmp为这个格子是否为墙,门,什么都没有,分别对应inf,1,0
if(pd(dx,dy) && dis[dx][dy]>dis[vx][vy]+tmp)
{
dis[dx][dy]=dis[vx][vy]+tmp;
q.push(dx);
q.push(dy);
}
}
}
return (dis[tx][ty]==INF?-:dis[tx][ty]);
} int main()
{
int n,m,i,j;
int x,y,d,t;
double sx,sy;
while(scanf("%d%d",&m,&n))
{
///m个墙,n个门
if(m==- && n==-) break; ymax=xmax=-;
memset(xa,EMPTY,sizeof(xa));
memset(ya,EMPTY,sizeof(ya));
for(i=; i<m; i++)
{
scanf("%d%d%d%d",&x,&y,&d,&t);
if(d) ///向上有墙
{
for(j=; j<t; j++)
ya[x][y+j+]=WALL;
ymax=max(y+t+,ymax);
xmax=max(x+,xmax);
}
else
{
for(j=; j<t; j++)
xa[x+j+][y]=WALL;
ymax=max(y+,ymax);
xmax=max(x+t+,xmax);
}
} for(i=; i<n; i++)
{
scanf("%d%d%d",&x,&y,&d);
if(d) ya[x][y+]=DOOR;
else xa[x+][y]=DOOR;
} scanf("%lf%lf",&sx,&sy);
if(!(sx>= && sx<= && sy>= && sy<=)) printf("0\n");
else printf("%d\n",bfs((int)sx+,(int)sy+));
}
return ;
}

参考:http://blog.csdn.net/wangjian8006/article/details/7997609

网格中的BFS,逆向(POJ2049)的更多相关文章

  1. 搜索(BFS)---计算在网格中从原点到特定点的最短路径长度

    计算在网格中从原点到特定点的最短路径长度 [[1,1,0,1], [1,0,1,0], [1,1,1,1], [1,0,1,1]] 题目描述: 1表示可以经过某个地方,求解从(0,0)位置到(tr,t ...

  2. VMware 设备VMnet0 上的网桥暂时关闭。此虚拟机无法与主机或网格中的其他计算机通信【转】

    今天克隆了一个win7的虚拟机,移动到我的本地.打开时发现虚拟机网格连接图标出现X断开连接,于是网上收了一堆答案无一个可用的,决定自己解决这个问题,解决过程如下: 1.报错图如下:设备VMnet0 上 ...

  3. csuoj 1117: 网格中的三角形

    http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1117 1117: 网格中的三角形 Time Limit: 3 Sec  Memory Limit: ...

  4. eclipse中使用mybatis-generator逆向代码生成工具问题解决记录

    问题一: eclipse中使用mybatis-generator逆向代码生成工具出现waiting for "building  workspace" 解决办法: 选择菜单栏的   ...

  5. P2295 MICE 网格中的DP

    题目描述 分析 很好的一道网格中的\(DP\)题 我们设\(f[x][y]\)为小象到达坐标为\((x,y)\)的点时看到的最少的老鼠的数量 但是这样定义是不好转移的,因为小象可能从上面的格子转移下来 ...

  6. sigma网格中水平压力梯度误差及其修正

    1.水平梯度误差产生 sigma坐标系下,笛卡尔坐标内水平梯度项对应形式为 \[\begin{equation} \left. \frac{\partial }{\partial x} \right| ...

  7. Istio(十一):向istio服务网格中引入虚拟机

    目录 一.模块概览 二.系统环境 三.虚拟机负载 3.1 虚拟机负载 3.2 单网络架构 3.3 多网络架构 3.4 Istio 中如何表示虚拟机工作负载? 四.实战:向istio Mesh中引入虚拟 ...

  8. n行m列的网格中含有的矩形数

    给你一个高为n ,宽为m列的网格,计算出这个网格中有多少个矩形 公式:[ n(n+1)*m(m+1)]/4 直接想问题比较复杂,可以先考虑矩形的长,再考虑矩形的高,由对称性可知最后的结果中m和n对称 ...

  9. (3)PyCharm中Flask工程逆向生成数据库表

    一.创建数据库 在mysql数据库中创建名为"movie"的数据库. 二.安装SQLAlchemy 三.安装PyMySQL 四.创建数据模型 在app/models.py中编写数据 ...

随机推荐

  1. Problem01 不死神兔

    题目:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子对数为多少? 程序分析:兔子的规律为数列1,1,2,3,5,8,13,21 ...

  2. linux 命令(Ubuntu)

    1. 我们可以使用下列的命令压缩一个目录: # zip -r archive_name.zip directory_to_compress 2. 下面是如果解压一个zip文档: # unzip arc ...

  3. Mybatis学习笔记16 - bind标签

    1.${}拼串进行模糊查询,不安全 示例代码: 接口定义: package com.mybatis.dao; import com.mybatis.bean.Employee; import java ...

  4. tomcat异常[0]--java.lang.ClassNotFoundException: org.apache.taglibs.standard.tlv.JstlCoreTLV

    自己建了一个项目,启动项目的时候,发生了java.lang.ClassNotFoundException: org.apache.taglibs.standard.tlv.JstlCoreTLV异常. ...

  5. Unity 将一个类序列化并以 ".asset" 类型存储在 Resources 文件夹下

    概念: 序列化 (Serialization)将对象的状态信息转换为可以存储或传输的形式的过程.在序列化期间,对象将其当前状态写入到临时或持久性存储区.以后,可以通过从存储区中读取或反序列化对象的状态 ...

  6. docker~service将容器日志输出到fluentd

    我们把微小的服务发布到docker里,然后实现docker service启动它,保证了服务的高可用性,然后把服务产生的日志输出到fluentd,由它进行过滤和转发,存储到elasticsearch里 ...

  7. HDU 4738——Caocao's Bridges——————【求割边/桥的最小权值】

     Caocao's Bridges Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u S ...

  8. 错误处理(Operation Result)方法

    自己开发的公众号,可以领取淘宝内部优惠券 问题 现在有一个FileStorageService类,继承自IStorageService,具体实现如下 public interface IStorage ...

  9. mysql存储过程游标加计划任务事件调度器

    存储过程加事件调度器 -- 存储过程 (多个)游标的使用 临时表的使用(让执行时间从一个小时降低到5分钟)DELIMITER $$ DROP PROCEDURE IF EXISTS `eval_cal ...

  10. 异步请求返回json对象

    后台mvc: var result = new { flag = ture, eMail = "949096562@qq.com"}; if (result.flag) { ret ...