首页 > 代码库 > 勘探油田
勘探油田
<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
- *
- 3 5
- *@*@*
- **@**
- *@*@*
- 1 8
- @@****@*
- 5 5
- ****@
- *@**@
- *@**@
- @@@*@
- @@**@
- 0 0
Sample Output
- 0
- 1
- 2
- 2
勘探油田
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。