改了好久,上午来实验室打出来了,运行就是不对,一直找啊找!还是没找到,最后突然停电了,打好的代码还没保存呢!

刚才来的时候又重新打了一遍!!!结果一个小小的错误wrong了好久!!!

在dfs值返回时两个NO的返回值不同写错了一个-100,一个-10,肯定不对了!!嘿嘿····,找到了,改了,提交了!对了!!

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%

#include<stdio.h>

#include<string.h>
#include<queue>

using namespace std;

struct node

{


int x,y,k;


int time;


friend bool operator<(node a,node b)


{


return a.time>b.time;


}

};

int visit[20][20][2];

int n,m,endx,endy,endk,ti,startx,starty,startk;

char a[20][20],b[20][20];

int dir[4][2]={0,1,1,0,-1,0,0,-1};

int judge(int x,int y,int k)

{


if(x>=0&&x<n&&y>=0&&y<m)


{


if(k==0&&a[x][y]!='*')


return 1;


if(k==1&&b[x][y]!='*')


return 1;


}


return 0;

}

int dfs(int startx,int starty,int startk)

{


priority_queue<node>q;


node cur,next;


int i,x,y,k;


cur.x=startx;cur.y=starty;


cur.k=startk;cur.time=0;


visit[startx][starty][startk]=1;


q.push(cur);


while(!q.empty())


{


next=q.top();


q.pop();


if(next.x==endx&&next.y==endy&&next.k==endk)


return next.time;


if(next.time>=ti)


return -100;


for(i=0;i<4;i++)


{


x=next.x+dir[i][0];


y=next.y+dir[i][1];


k=next.k;


if(judge(x,y,k)&&visit[x][y][k]==0)


{


if(k==0&&a[x][y]=='#')


{


cur.time=next.time+1;


cur.k=1;


cur.x=x;cur.y=y;


q.push(cur);


visit[x][y][1]=1;


continue;


}


if(k==1&&b[x][y]=='#')


{


cur.time=next.time+1;


cur.k=0;


cur.x=x;cur.y=y;


q.push(cur);


visit[x][y][0]=1;


continue;


}


cur.time=next.time+1;


cur.k=next.k;


cur.x=x;cur.y=y;


visit[x][y][k]=1;


q.push(cur);


}


}

}


return -100;

}

int main()

{


int T,i,j;


scanf("%d",&T);


while(T--)


{


scanf("%d%d%d",&n,&m,&ti);


memset(visit,0,sizeof(visit));


for(i=0;i<n;i++)


scanf("%s",a[i]);


for(i=0;i<n;i++)


scanf("%s",b[i]);


for(i=0;i<n;i++)


for(j=0;j<m;j++)


{


if(a[i][j]=='#'&&b[i][j]=='#')


{a[i][j]='*';b[i][j]='*';}


if(a[i][j]=='#'&&b[i][j]=='*')


a[i][j]='*';


if(a[i][j]=='*'&&b[i][j]=='#')


b[i][j]='*';


}


for(i=0;i<n;i++)


for(j=0;j<m;j++)


{


if(a[i][j]=='P')


{


endx=i;endy=j;endk=0;


}


if(b[i][j]=='P')


{


endx=i;endy=j;endk=1;


}


if(a[i][j]=='S')


{


startx=i;starty=j;startk=0;


}


if(b[i][j]=='S')


{


startx=i;starty=j;startk=1;


}


}


int ans;


ans=dfs(startx,starty,startk);


if(ans<=ti&&ans!=-100)


printf("YES\n");


else


printf("NO\n");


}


return 0;

}

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2102

hdu 2102 A计划(优先队列+dfs)的更多相关文章

  1. HDU 2102 A计划(BFS/DFS走迷宫)

    A计划 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submis ...

  2. hdu 2102 A计划

    题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=2102 A计划 Description 可怜的公主在一次次被魔王掳走一次次被骑士们救回来之后,而今,不幸 ...

  3. HDU 2102 A计划(两层地图加时间限制加传送门的bfs)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=2102 A计划 Time Limit: 3000/1000 MS (Java/Others)    Me ...

  4. hdu 2102 A计划 具体题解 (BFS+优先队列)

    题目链接:pid=2102">http://acm.hdu.edu.cn/showproblem.php?pid=2102 这道题属于BFS+优先队列 開始看到四分之中的一个的AC率感 ...

  5. [HDU 2102] A计划(搜索题,典型dfs or bfs)

    A计划 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  6. HDU 2102 A计划(DFS)

    题目链接 Problem Description 可怜的公主在一次次被魔王掳走一次次被骑士们救回来之后,而今,不幸的她再一次面临生命的考验.魔王已经发出消息说将在T时刻吃掉公主,因为他听信谣言说吃公主 ...

  7. HDU 2102 A计划 (BFS或DFS)

    题意:中文题. 析:是一个简单的搜索,BFS 和 DFS都可行, 主要是这个题有一个坑点,那就是如果有一层是#,另一个层是#或者*,都是过不去的,就可以直接跳过, 剩下的就是一个简单的搜索,只不过是两 ...

  8. hdu 2102 a计划问题。。 双层dfs问题

    Problem Description 可怜的公主在一次次被魔王掳走一次次被骑士们救回来之后,而今,不幸的她再一次面临生命的考验.魔王已经发出消息说将在T时刻吃掉公主,因为他听信谣言说吃公主的肉也能长 ...

  9. HDU 2102 A计划 DFS与BFS两种写法 [搜索]

    1.题意:一位公主被困在迷宫里,一位勇士前去营救,迷宫为两层,规模为N*M,迷宫入口为(0,0,0),公主的位置用'P'标记:迷宫内,'.'表示空地,'*'表示墙,特殊的,'#'表示时空传输机,走到这 ...

随机推荐

  1. <一> SQL 基础

    删除数据库 drop database database-name 创建新表格 create table tablename (col1 type1 [not null] [primary key], ...

  2. Discuz CDN优化方案

    DZ整体来说CDN是有点蛋疼的,因为毕竟琐碎,貌似大部分帖子都没有说全,这里罗列一下,给在用的孩儿们一点参考: 1.在后台设置CSS/JS走CDN路径,具体[全局]-[性能优化]-[服务器优化] 2. ...

  3. Android之监测手机网络状态的广播

    Android之监测手机网络状态的广播 Android 监控网络状态 Android利用广播监听设备网络连接(断网)的变化情况

  4. android activity在横竖屏切换的时候不重新调用onCreate方法

    在安卓系统中,横竖屏切换会默认重新调用onCreate等生命周期方法,如果此时有一些临时数据没有保存下来,很有可能会导致该数据丢失. 因此我们可以进行以下设置,来避免恒切换时重新调用onCreate方 ...

  5. NSMutableArray,NSMutableDictionary的内存管问题

    今天做项目遇到一个问题,在一个类中定义了一个可变数组,使用的是copy的内存管理策略 当往数组中添加包装好的基本数据的时候,程序直接崩溃了.解决方法:把copy换成strong就不会崩溃了; 后来做了 ...

  6. flash 类和对象的关系

    每个具体的对象后面都隐藏着抽象的类. flash 中as3.0中所有的类,都是为了创建对象所用的.反过来,所创建的任何具体对象都隐藏着抽象的类. 类可以把它看做函数,类的属性是函数的数据,类的方法是函 ...

  7. *[topcoder]LittleElephantAndBalls

    http://community.topcoder.com/stat?c=problem_statement&pm=12758&rd=15704 topcoder的题经常需要找规律,而 ...

  8. MyGui 3.2.0(OpenGL平台)的编译(五篇文章)

    MyGui是一个用来创建用户图形界面的库,用于游戏和3D应用程序.这个库的主要目标是达到:快速.灵活.易用. 1.下载准备: 源代码:http://svn.code.sf.net/p/my-gui/c ...

  9. 目录重定向的源代码工程( linux平台利用VFS实现目录重定向驱动)虚拟磁盘MINIPORT驱动代码(雨中风华)

    http://download.csdn.net/user/fanxiushu/uploads/2 http://download.csdn.net/user/fanxiushu/uploads/1

  10. RxJava学习(一)

    注意:文字和图片转载自抛物线博客 参考:http://gank.io/post/560e15be2dca930e00da1083 RxJava 到底是什么 一个词:异步. RxJava 在 GitHu ...