长沙网站免费建站/青岛百度整站优化服务
版权声明:本文为CSDN博主「Xiyou_limeng」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/ldx19980108/article/details/76324307
油田问题
问题:GeoSurvComp地质调查公司负责探测地下石油储藏。 GeoSurvComp现在在一块矩形区域探测石油,并把这个大区域分成了很多小块。他们通过专业设备,来分析每个小块中是否蕴藏石油。如果这些蕴藏石油的小方格相邻,那么他们被认为是同一油藏的一部分。在这块矩形区域,可能有很多油藏。你的任务是确定有多少不同的油藏。
input: 输入可能有多个矩形区域(即可能有多组测试)。每个矩形区域的起始行包含m和n,表示行和列的数量,1<=n,m<=100,如果m =0表示输入的结束,接下来是n行,每行m个字符。每个字符对应一个小方格,并且要么是’*’,代表没有油,要么是’@’,表示有油。
output: 对于每一个矩形区域,输出油藏的数量。两个小方格是相邻的,当且仅当他们水平或者垂直或者对角线相邻(即8个方向)。
//A - Oil Deposits
#include<stdio.h>
#include<string.h>
#include<stdlib.h>char a[105][105];
int n,m,result;
int dir[8][2]={{1,0},{-1,0},{0,1},{0,-1},{1,1},{-1,-1},{1,-1},{-1,1}};//表示8个方向int check(int x,int y)//检查是否有油田
{if(x>=0&&x<m&&y>=0&&y<n&&a[x][y]=='@')return 1;return 0;
}int dfs(int x, int y)
{int i,xx,yy;if(check(x,y)){a[x][y]='.'; //统计之后就可以把该油田标记,且不用恢复(要不会重复),//也可以用一个数组来存每个点的访问情况,但是感觉没必要,浪费空间for(i=0;i<8;i++){xx=x+dir[i][0];yy=y+dir[i][1];dfs(xx,yy);//依次检查8个方向}return 1;}return 0;
}int main(void)
{int i,j;while(scanf("%d %d",&m,&n)==2){if(m==0&&n==0)break;result = 0;memset(a,0,sizeof(a));for(i=0;i<m;i++)scanf("%s",a[i]);for(i=0;i<m;i++)//在每一个点都搜索一次{for(j=0;j<n;j++){if(dfs(i,j))//找到油田就可以将结果加1result++;}}printf("%d\n",result);}return 0;
}
————————————————
版权声明:本文为CSDN博主「Xiyou_limeng」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/ldx19980108/article/details/76324307
``
这里意思是把每块油田及其邻近油田全部去除,再去找下一个油田。