hdu 5040bfs+优先队列 需要存状态
/*
剪枝:四秒后状态会变得和原来一样,所以四秒后如果再经过这个点肯定不是最优的舍去
易错点:在一个是从.到.这两个点都没有被照到并且不是摄像机,也可能需要等3秒,因为后面的结果可能再这三秒中发生改变,要单独判断
*/
#include<stdio.h>
#include<queue>
#include<iostream>
#include<string.h>
#include<algorithm>
using namespace std;
#define N 510
char s[N][N];
struct node {
int x,y,time;
friend bool operator<(node a,node b) {//优先队列
return a.time>b.time;//从小到大出队
}
}ss,tt,next,cu;
int ma[N][N][4],n;
int judge(int x,int y) {
if(x>=1&&x<=n&&y>=1&&y<=n)
return 1;
return 0;
}
void update(int i,int j,char ch) {//存关于时间的状态
if(ch=='N') {
if(judge(i-1,j))ma[i-1][j][0]=1;
if(judge(i,j+1))ma[i][j+1][1]=1;
if(judge(i+1,j))ma[i+1][j][2]=1;
if(judge(i,j-1))ma[i][j-1][3]=1;
}
if(ch=='W') {
if(judge(i,j-1))ma[i][j-1][0]=1;
if(judge(i-1,j))ma[i-1][j][1]=1;
if(judge(i,j+1))ma[i][j+1][2]=1;
if(judge(i+1,j))ma[i+1][j][3]=1;
}
if(ch=='S') {
if(judge(i+1,j))ma[i+1][j][0]=1;
if(judge(i,j-1))ma[i][j-1][1]=1;
if(judge(i-1,j))ma[i-1][j][2]=1;
if(judge(i,j+1))ma[i][j+1][3]=1;
}
if(ch=='E') {
if(judge(i,j+1))ma[i][j+1][0]=1;
if(judge(i+1,j))ma[i+1][j][1]=1;
if(judge(i,j-1))ma[i][j-1][2]=1;
if(judge(i-1,j))ma[i-1][j][3]=1;
}
}
int dis[4][2]={1,0,-1,0,0,1,0,-1},vis[N][N][5];
int bfs() {
int i,xx,yy;
priority_queue<node>q;
memset(vis,0,sizeof(vis));
ss.time=0;
q.push(ss);
while(!q.empty()) {
ss=q.top();
q.pop();
if(ss.x==tt.x&&ss.y==tt.y)return ss.time;
//if(ss.time>=800000)break
cu=ss;cu.time++;//考虑不够完善,刚开始写的时候写到了for循环里面,这是不对的,因为。到。 等不超过四秒可能会有不同结果。
if(vis[cu.x][cu.y][cu.time%4]==0) {//等待,最多不超过三秒
vis[cu.x][cu.y][cu.time%4]=1;
q.push(cu);
};
for(i=0;i<4;i++) {
next.x=xx=ss.x+dis[i][0];
next.y=yy=ss.y+dis[i][1];
if(judge(xx,yy)&&s[xx][yy]!='#') {
// printf("%d %d\n",xx,yy);
if(s[ss.x][ss.y]!='.'||ma[ss.x][ss.y][ss.time%4]||ma[xx][yy][ss.time%4]||s[xx][yy]!='.') {//如果当前点或者下一个点被照到,或者当前点和下一个点都是摄像机,那么移动的话需要时间+3
next.time=ss.time+3;
if(vis[next.x][next.y][next.time%4]==0) {
vis[next.x][next.y][next.time%4]=1;
q.push(next);
}
continue;
}
next.time=ss.time+1;
if(vis[xx][yy][next.time%4]==0) {//如果是.到.的话也可以不等待
vis[xx][yy][next.time%4]=1;
q.push(next);
}
}
}
}
return -1;
}
int main() {
int i,j,t,f=0;
scanf("%d",&t);
while(t--) {
scanf("%d",&n);
for(i=1;i<=n;i++)
scanf("%s",s[i]+1);
memset(ma,0,sizeof(ma));
for(i=1;i<=n;i++)
for(j=1;j<=n;j++) {
if(s[i][j]=='M') {
s[i][j]='.';
ss.x=i;
ss.y=j;
}
else
if(s[i][j]=='T') {
s[i][j]='.';
tt.x=i;
tt.y=j;
}
else
if(s[i][j]!='.')
update(i,j,s[i][j]);
}
printf("Case #%d: %d\n",++f,bfs());
}
return 0;
}
hdu 5040bfs+优先队列 需要存状态的更多相关文章
- ASP.NET状态管理之四(暂存状态HttpContext.Items)
ASP.NET提供一个类System.Web.HttpContext ,用来表示上下文,此对象有一个属性Items 暂存状态就是利用HttpContext.Items属性来存放数据 MSDN中Http ...
- hdu 4778 Gems Fight! 博弈+状态dp+搜索
作者:jostree 转载请注明出处 http://www.cnblogs.com/jostree/p/4102743.html 题目链接:hdu 4778 Gems Fight! 博弈+状态dp+搜 ...
- hdu 5025 Saving Tang Monk 状态压缩dp+广搜
作者:jostree 转载请注明出处 http://www.cnblogs.com/jostree/p/4092939.html 题目链接:hdu 5025 Saving Tang Monk 状态压缩 ...
- HDU 3681 Prison Break(状态压缩dp + BFS)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3681 前些天花时间看到的题目,但写出不来,弱弱的放弃了.没想到现在学弟居然写出这种代码来,大吃一惊附加 ...
- HDU 3442 Three Kingdoms(状态压缩 + BFS )
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3442 题目大意:三国时期,刘备逃亡.给定一个最大为50*50的地图,刘备在地图中只能往4个方向走. 地 ...
- HDU 4628 Pieces(DP + 状态压缩)
Pieces 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4628 题目大意:给定一个字符串s,如果子序列中有回文,可以一步删除掉它,求把整个序列删除 ...
- HDU 1074 Doing Homework【状态压缩DP】
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1074 题意: 给定作业截止时间和完成作业所需时间,比截止时间晚一天扣一分,问如何安排作业的顺序使得最 ...
- hdu 5306 优先队列
用到优先队列 #include<iostream> #include<string> #include<algorithm> #include<cstdio& ...
- HDU 4006 优先队列
The kth great number Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65768/65768 K (Java/Oth ...
随机推荐
- 实数类型c++
数据类型 定义标识符 数值范围 占字节数 有效位数 单精度浮点数 float -3.4E+38-3.4E+38 4(32位) 6-7位 双精度浮点数 double -1.7E+308-1.7E+308 ...
- select多选
1.css <style> .divBox{ width:400px; margin:100px auto; } .divBox span{ vertical-align:top; dis ...
- [转]微信开发.Net 接入示例
本文转自:http://my.oschina.net/lcak/blog/219618 微信公众平台接口开发官方仅提供了 PHP 接入示例代码, 网上找到的.Net代码多半需要积分下载, 所以自己写了 ...
- nginx connect failed (110- Connection timed out) 问题排查
首先排查 ping 下 nginx 与代理服务是否ping 的通,带端口的,telnet 下端口号是否是通的,本次遇到问题为 telnet 发现有台服务器不通,原因是端口未开放
- JDBC和数据库连接池
JDBC是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口组成. ● JDBC ● C3P0 ● DRUID 一.JDBC ...
- (3)左右值再探与decltype
Decltype 类型指示符 “引用从来都作为其所指对象的同义词出现,只有用在decltype处是一个例外” 理解: Decltype和auto区别: 1. auto是从表达式类型推断出要定义 ...
- android视频播放器系列(二)——VideoView
最近在学习视频相关的知识,现在也是在按部就班的一步步的来,如果有同样需求的同学可以跟着大家一起促进学习. 上一节说到了可以使用系统播放器以及浏览器播放本地以及网络视频,但是这在很大程度上并不能满足我们 ...
- 如何解决数据库中,数字+null=null
如何解决数据库中,数字+null=null 我使用SQLServer,做一个 update 操作,累计一个数.在数据库中,为了方便,数据库中这个字段我设为允许为空,并且设置了默认值为 0 .但是在新增 ...
- ThinkPHP---插件highcharts
[一]概论 (1)介绍 基于jquery开发的国外图标插件,统计图,折线图,饼状图等常常用到. 国内也有一款类似插件echarts,由百度开发. (2)官网:www.highcharts.com ...
- 第二节:Css重写样式
一丶 进入浏览器---->F12----->找到要修改的区域的Style 进行重写Css样式 二丶打开新页面 window.open("/Persitent/OtherIndex ...