码迷,mamicode.com
首页 > 其他好文 > 详细

UVa 572 - Oil Deposits (简单dfs)

时间:2015-07-30 11:29:38      阅读:124      评论:0      收藏:0      [点我收藏+]

标签:uva   dfs   

Description

GeoSurvComp地质调查公司负责探测地下石油储藏。 GeoSurvComp现在在一块矩形区域探测石油,并把这个大区域分成了很多小块。他们通过专业设备,来分析每个小块中是否蕴藏石油。如果这些蕴藏石油的小方格相邻,那么他们被认为是同一油藏的一部分。在这块矩形区域,可能有很多油藏。你的任务是确定有多少不同的油藏。

Input

输入可能有多个矩形区域(即可能有多组测试)。每个矩形区域的起始行包含m和n,表示行和列的数量,1<=n,m<=100,如果m =0表示输入的结束,接下来是n行,每行m个字符。每个字符对应一个小方格,并且要么是‘*‘,代表没有油,要么是‘@‘,表示有油。

Output

对于每一个矩形区域,输出油藏的数量。两个小方格是相邻的,当且仅当他们水平或者垂直或者对角线相邻(即8个方向)。

Sample Input

 
1 1
*
3 5
*@*@*
**@**
*@*@*
1 8
@@****@*
5 5 
****@
*@@*@
*@**@
@@@*@
@@**@
0 0 


虽热很简单 ,但是也感觉陌生没做过搜索了…… 这两天训练赛也很不在状态。

#include<iostream>
#include<sstream>
#include<algorithm>
#include<cstdio>
#include<string.h>
#include<cctype>
#include<string>
#include<cmath>
#include<vector>
#include<stack>
#include<queue>
#include<map>
#include<set>
using namespace std;
const int INF=110;
char cnt[INF][INF];
int vis[INF][INF];
int dir[][2]= {{1,0},{0,1},{-1,0},{0,-1},{-1,-1},{1,1},{-1,1},{1,-1}};
int n,m;
void dfs(int x,int y)
{
    for(int i=0; i<8; i++)
    {
        int tx=x+dir[i][0];
        int ty=y+dir[i][1];
        if(tx >= 1 && tx <= n && ty>=1 && ty<=m && cnt[tx][ty]=='@' && !vis[tx][ty])
        {
            vis[tx][ty]=1;
            dfs(tx,ty);
        }
    }
}

int main()
{

    while(cin>>n>>m,n+m)
    {
        for(int i=1; i<=n; i++)

            scanf("%s",cnt[i]+1);
        int count=0;
        memset(vis,0,sizeof(vis));
        for(int i=1; i<=n; i++)
        {
            for(int j=1; j<=m; j++)
            {
                if(cnt[i][j]=='@'&&!vis[i][j])
                {
                    count++;
                    dfs(i,j);
                }
            }

        }
        cout<<count<<endl;
    }
    return 0;
}



版权声明:本文为博主原创文章,未经博主允许不得转载。

UVa 572 - Oil Deposits (简单dfs)

标签:uva   dfs   

原文地址:http://blog.csdn.net/lsgqjh/article/details/47145199

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!