[POI2007]洪水pow bfs
2017-08-21 15:59
232 查看
发现:只在所有自己的城市建水泵一定是最优解。
所以对自己的城市按高度排序,该城市不用建的前提是从他出发经过一条高度都小于等于他的路径能到达一个已经修建水泵的
sort+bfs......
所以对自己的城市按高度排序,该城市不用建的前提是从他出发经过一条高度都小于等于他的路径能到达一个已经修建水泵的
sort+bfs......
#include<cstdio> #include<cstring> #include<iostream> #include<algorithm> #include<cmath> #define N 1005 using namespace std; int dx[4]={-1,1,0,0},dy[4]={0,0,-1,1}; int bo ,num,n,m,NOW,exi ; int qx[N*N],qy[N*N],g ,ans; bool vis ; struct data{ int x,y,h; bool operator < (const data &a)const{return h<a.h;} }d[N*N]; void add(int x,int y,int h){d[++num].x=x;d[num].y=y;d[num].h=h;bo[x][y]=1;} bool bfs(int x,int y){ NOW++;bo[x][y]=NOW; qx[1]=x;qy[1]=y; int h=1,t=1,nx,ny,nh=g[x][y]; while(h<=t){ nx=qx[h];ny=qy[h++]; for(int i=0;i<4;i++) if(exi[nx+dx[i]][ny+dy[i]]&&bo[nx+dx[i]][ny+dy[i]]!=NOW&&g[nx+dx[i]][ny+dy[i]]<=nh){ bo[nx+dx[i]][ny+dy[i]]=NOW; qx[++t]=nx+dx[i];qy[t]=ny+dy[i]; if(vis[nx+dx[i]][ny+dy[i]])return 1; } } return 0; } int main(){ scanf("%d%d",&n,&m); for(int i=1;i<=n;i++) for(int j=1;j<=m;j++){ exi[i][j]=1; scanf("%d",&g[i][j]); if(g[i][j]>0)add(i,j,g[i][j]); else g[i][j]=-g[i][j]; } sort(d+1,d+num+1); for(int i=1;i<=num;i++){ if(!bfs(d[i].x,d[i].y))ans++; vis[d[i].x][d[i].y]=1; } printf("%d\n",ans); return 0; }
相关文章推荐
- [POI2007]洪水pow bfs
- 【BZOJ】1104: [POI2007]洪水pow
- BZOJ1104: [POI2007]洪水pow
- BZOJ 1104 POI2007 洪水pow 并查集
- bzoj1104 [POI2007]洪水pow
- [BZOJ]1104: [POI2007]洪水pow
- BZOJ1104: [POI2007]洪水pow
- 并查集 [POI2007]洪水pow
- BZOJ 1104: [POI2007]洪水pow 并查集
- [POI2007]洪水pow 并查集
- BZOJ1104 : [POI2007]洪水pow
- BZOJ 1104: [POI2007]洪水pow 并查集
- BZOJ1104 [POI2007]洪水pow——并查集+乱搞
- Luogu345: [POI2007]POW-The Flood
- 【BZOJ1098】[POI2007]办公楼biu【BFS/DFS】【链表优化】【补图】
- 【LuoguP3457】[POI2007]POW-The Flood
- BZOJ_1098_[POI2007]办公楼biu_链表优化BFS
- 【BZOJ】1098 [POI2007]办公楼biu 链表+BFS
- 洪水 Pow
- 洪水_codevs3411_bfs