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
- HDU 1241Oil Deposits
- HDU---1241Oil Deposits
- Hdu 1241 Oil Deposits
- Hdu 1241 - Oil Deposits
- HDU-1241:Oil Deposits
- hdu 1241 Oil Deposits
- hdu 1241 Oil Deposits
- hdu 1241 Oil Deposits
- hdu - 1241 - Oil Deposits
- HDU-1241Oil Deposits
- hdu 1241 Oil Deposits
- hdu 1241 Oil Deposits
- HDU 1241 Oil Deposits
- hdu 1241 Oil Deposits
- hdu 1241 Oil Deposits
- HDU 1241 Oil Deposits
- hdu-1241-Oil Deposits
- hdu 1241 Oil Deposits
- poj 1003:Hangover
- 数码管学习随记
- Cracking the coding interview--Q9.4
- java线程安全的单例模式
- execve的使用方法
- hdu 1241:Oil Deposits
- 如何查看域名的历史使用记录,以前注册信息,whois,是否有被K记录
- 集合排列脑图
- try catch包含多个异常时会怎么执行
- tiny6410裸机实验第8章--------------中断(中断向量寄存器)
- sql server2008 分页语句
- C++大随机整数的产生,排序和查找
- 关于 C语言中typedef struct 和 struct
- 将php数组或者对象传递给javascript的方法