设为首页 加入收藏

TOP

hdu4308之BFS (二)
2014-11-23 20:10:35 来源: 作者: 【 】 浏览:13
Tags:hdu4308 BFS
de #include #include #include #include #include #include #define INF 99999999 using namespace std; const int MAX=5000+10; string Map[MAX]; int n,m,v,size,s[MAX][2];//s记录p的位置 int dir[4][2]={0,1,0,-1,1,0,-1,0}; bool mark[MAX]; struct Node{ int x,y,t; Node(){} Node(int X,int Y,int T):x(X),y(Y),t(T){} }start; void CalculateP(){ size=0; for(int i=0;iq; Node oq,next; q.push(start); mark[start.x*m+start.y]=true; while(!q.empty()){ oq=q.front(); q.pop(); for(int i=0;i<4;++i){ next=Node(oq.x+dir[i][0],oq.y+dir[i][1],oq.t);; if(next.x<0 || next.y<0 || next.x>=n || next.y>=m)continue; if(mark[next.x*m+next.y] || Map[next.x][next.y] == '#')continue; mark[next.x*m+next.y]=true; if(Map[next.x][next.y] == 'C')return next.t; if(Map[next.x][next.y] == 'P'){ int len=q.size(); for(int j=0;j>n>>m>>v){ for(int i=0;i>Map[i]; CalculateP(); int temp=BFS(); if(temp<0)cout<<"Damn teoy!"<

首页 上一页 1 2 下一页 尾页 2/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇hdu4433 locker 密码锁(枚举) 下一篇HDU 1829 A Bug's Life (并查..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·C 内存管理 | 菜鸟教 (2025-12-26 20:20:37)
·如何在 C 语言函数中 (2025-12-26 20:20:34)
·国际音标 [ç] (2025-12-26 20:20:31)
·微服务 Spring Boot (2025-12-26 18:20:10)
·如何调整 Redis 内存 (2025-12-26 18:20:07)