hdu 1241:Oil Deposits

来源:互联网 发布:windows xp 独木成林 编辑:程序博客网 时间:2024/06/02 05:09

一道bfs的题。背景为石油探测。一个矩阵,以‘@’代表石油,以‘*’代表岩石,求有几块相连的油田,其中对角相连也算作相连。

 

记录地图同时用sum记录‘@’的数量。用bfs搜索‘@’,用total计算油田数。每调用一次bfs,油田数total加1。bfs中每搜索到一个‘@’,sum便减1。最后输出total。其实sum没有什么用处,不过不影响代码,存在着可以变得更加严密一点,也就不删除了。


#include <cstdio>#include <cstring>#include <queue>#include <iostream>using namespace std;typedef struct address{int x,y;}ad;const int MAXN=110;bool map[MAXN][MAXN]={0};int sum;queue <ad> p;void bfs(int m,int n){while(!p.empty()){ad a;a=p.front();p.pop();ad b;if(a.x-1>=0 && a.y-1>=0 && map[a.x-1][a.y-1]){b.x=a.x-1;b.y=a.y-1;p.push(b);sum--;map[b.x][b.y]=0;}if(a.x-1>=0 && map[a.x-1][a.y]){b.x=a.x-1;b.y=a.y;p.push(b);sum--;map[b.x][b.y]=0;}if(a.x-1>=0 && a.y+1<n && map[a.x-1][a.y+1]){b.x=a.x-1;b.y=a.y+1;p.push(b);sum--;map[b.x][b.y]=0;}if(a.y-1>=0 && map[a.x][a.y-1]){b.x=a.x;b.y=a.y-1;p.push(b);sum--;map[b.x][b.y]=0;}if(a.y+1<n && map[a.x][a.y+1]){b.x=a.x;b.y=a.y+1;p.push(b);sum--;map[b.x][b.y]=0;}if(a.x+1<m && a.y-1>=0 && map[a.x+1][a.y-1]){b.x=a.x+1;b.y=a.y-1;p.push(b);sum--;map[b.x][b.y]=0;}if(a.x+1<m && map[a.x+1][a.y]){b.x=a.x+1;b.y=a.y;p.push(b);sum--;map[b.x][b.y]=0;}if(a.x+1<m && a.y+1<n && map[a.x+1][a.y+1]){b.x=a.x+1;b.y=a.y+1;p.push(b);sum--;map[b.x][b.y]=0;}}}int main(){int m,n;while(cin>>m>>n){if(!m && !n)break;int i,j;int total=0;sum=0;memset(map,0,sizeof(map));for(i=0;i<m;i++){for(j=0;j<n;j++){char plot;cin>>plot;if(plot=='@') {map[i][j]=1;sum++;}}}for(i=0;i<m;i++){for(j=0;j<n;j++){if(map[i][j]){ad b;b.x=i;b.y=j;p.push(b);map[i][j]=0;sum--;total++;bfs(m,n);}}}cout<<total<<endl;}return 0;}


0 0