zoukankan      html  css  js  c++  java
  • POJ 2386 Lake Counting

    http://poj.org/problem?id=2386

    思路 将联通的W变为 . dfs的次数 就是pound的个数

     1 #include <iostream>
     2 #include <stdio.h>
     3 #include <string.h>
     4 
     5 using namespace std;
     6 
     7 const int maxsize = 128;
     8 int M,N,cnt = 0;
     9 int d[2][8] = { {-1, -1, -1, 0, 1, 1, 1, 0},
    10                 {-1, 0, 1, 1, 1, 0, -1, -1},
    11               };
    12 char court[maxsize][maxsize];
    13 
    14 //思路 : 随机选择一个水点 然后深搜将周围的所有水点变为.直到没有W为止
    15 //那么深搜的次数 就是pound的个数
    16 bool check(int x, int y)
    17 {
    18     if (x < 0 || x >= M || y < 0 || y >= N) return false;
    19     if (court[x][y] == '.') return false;
    20     return true;
    21 }
    22 void dfs(int x, int y)
    23 {
    24     int nx, ny;
    25     court[x][y] = '.';//将相邻的所有W置为.
    26     for (int i = 0; i <8; i++)
    27     {
    28         nx = x+d[0][i];
    29         ny = y+d[1][i];
    30         if (check(nx,ny))
    31         {
    32             dfs(nx, ny);
    33         }
    34     }
    35 }
    36 
    37 int main()
    38 {
    39     //POJ是不能这样滴
    40    #ifndef OLINE_JUDGE
    41    freopen("in.txt", "r", stdin);
    42    #endif // OLINE_JUDGE
    43 
    44    while (~scanf("%d%d", &M, &N))
    45    {
    46        cnt = 0;
    47        getchar();
    48        for (int i = 0;i < M; i++)
    49        {
    50            gets(court[i]);
    51        }
    52        while (1)
    53        {
    54            int x, y, s = 0;
    55            for (int i = 0; i < M; i++)
    56            {
    57                for (int j = 0; j < N; j++)
    58                {
    59                    if (court[i][j] == 'W')
    60                    {
    61                        s++;
    62                        x = i;
    63                        y = j;
    64                    }
    65                }
    66            }
    67            if (s == 0) break;
    68            dfs(x,y);
    69            //for (int i = 0; i < M; i++) printf("%s
    ",court[i]);
    70            //putchar('
    ');
    71            cnt++;//进行多少次dfs()就有多少个pound
    72        }
    73        /*
    74        改进:书上代码 自己想得太多
    75        for (int i = 0; i < M; i++)
    76         for (int j = 0; j < N; j++)
    77        {
    78          if (court[i][j] == 'W')
    79          {
    80             dfs(i,j);
    81             cnt++;
    82          }
    83        }
    84 
    85        */
    86        printf("%d
    ", cnt);
    87    }
    88    return 0;
    89 
    90 }
    91 //时间复杂度 因为每个格子至多被访问一次 然后会想8个方向搜索 所以时间复杂度 O(8*M*N)
  • 相关阅读:
    WinEdt && LaTex(五)—— 内容的排版
    WinEdt && LaTex(五)—— 内容的排版
    WinEdt && LaTex(四)—— 自定义新命令(newcommand、def)
    WinEdt && LaTex(四)—— 自定义新命令(newcommand、def)
    独立与条件独立
    “人”之为人:道德+技能+创新
    android之ListPreference的用法_PreferenceActivity用法
    【Oracle】删除重复记录
    wso2esb源码编译总结
    .net网站开发(设计):1.什么是MVC模式
  • 原文地址:https://www.cnblogs.com/oscar-cnblogs/p/6291447.html
Copyright © 2011-2022 走看看