首页 > 代码库 > 勘探油田

勘探油田

<pre name="code" class="cpp">#include <iostream>
#include <cstring>
using namespace std;
char a[100][100];
int b[100][100],n,m;
int x[]={0,-1,-1,-1,0,1,1,1};
int y[]={1,1,0,-1,-1,-1,0,1};
void dfs(int i,int j)//深度搜索
{
	int tx,ty,k;
	b[i][j]=0;
	for (k=0;k<8;++k)
	{
		tx=i+x[k];
		ty=j+y[k];
		if(a[tx][ty]=='@'&&tx>0&&tx<=n&&ty>0&&ty<=m&&b[tx][ty]==1)
		{
			dfs(tx,ty);
		}
	}
}
int queue[10000][2];
void bfs(int i,int j)//广度搜索
{
	int k,tx,ty,cx,cy;
	int head=0,tail=0;
	queue[tail][0]=i;
	queue[tail][1]=j;
	tail++;
	b[i][j]=0;
	while(head<tail)
	{
		cx=queue[head][0];
		cy=queue[head][1];
		head++;
		for (k=0;k<8;++k)
		{
			tx=cx+x[k];
			ty=cy+y[k];
			if (tx>0&&tx<=n&&ty>0&&ty<=m&&b[tx][ty]==1&&a[tx][ty]=='@')
			{
				queue[tail][0]=tx;
				queue[tail][1]=ty;
				tail++;
				b[tx][ty]=0;
			}
		}
	}
}
int main()
{
	int i,j,sum;
	while(true)
	{
		cin >> n >> m;
		if (n==0&&m==0)
		{
			break;
		}
		for (i=1;i<=n;++i)
		{
			for(j=0;j<=m;++j)
			{
				b[i][j]=1;
			}
		}
		sum=0;
		for (i=1;i<=n;++i)
		{
			cin >> a[i] ;
		}
		for (i=1;i<=n;++i)
		{
			for (j=1;j<=m;++j)
			{
				if (a[i][j]=='@'&&b[i][j]==1)
				{
					sum++;
					/*dfs(i,j);*/
					bfs(i,j);
				}
			}
		}
		cout << sum << endl;
	}
	return 0;
}


勘探油田

Description

某石油勘探公司正在按计划勘探地下油田资源。他们工作在一片长方形的地域中,首先将该地域划分为许多小正方形区域,然后使用探测设备分别探测每一块小正方形区域是否有油。若在一块小正方形区域中探测到有油,则标记为’@’,否则标记为’*’。如果两个相邻区域都为1,那么它们同属于一个石油带,一个石油带可能包含很多小正方形区域,而你的任务是要确定在一片长方形地域中有多少个石油带。 所谓相邻,是指两个小正方形区域上下、左右、左上右下或左下右上同为’@’。

Input

输入数据将包含一些长方形地域数据,每个地域数据的第一行有两个正整数m和n,表示该地域为m*n个小正方形所组成,如果m为0,表示所有输入到此结束。否则,后面m(1≤m≤100)行数据,每行有n(1≤n≤100)个字符,每个字符为’@’或’*’,表示有油或无油。每个长方形地域中,’@’的个数不会超过100。

Output

每个长方形地域,输出油带的个数,每个油带值占独立的一行。油带值不会超过100。

Sample Input

  1. 1 1
  2. *
  3. 3 5
  4. *@*@*
  5. **@**
  6. *@*@*
  7. 1 8
  8. @@****@*
  9. 5 5
  10. ****@
  11. *@**@
  12. *@**@
  13. @@@*@
  14. @@**@
  15. 0 0

Sample Output

  1. 0
  2. 1
  3. 2
  4. 2

勘探油田