zoukankan      html  css  js  c++  java
  • NYOJ 27 水池数目

     1 #include<iostream>
     2 #include<memory.h>
     3 using namespace std;
     4 
     5 int map[105][105];
     6 bool visit[105][105];
     7 
     8 void dfs(int i, int j)
     9 {
    10     visit[i][j] = true;
    11     if(map[i-1][j] == 1 && !visit[i-1][j]) dfs(i-1,j);
    12     if(map[i+1][j] == 1 && !visit[i+1][j]) dfs(i+1,j);
    13     if(map[i][j-1] == 1 && !visit[i][j-1]) dfs(i,j-1);
    14     if(map[i][j+1] == 1 && !visit[i][j+1]) dfs(i,j+1);
    15     map[i][j] = 0;
    16 }
    17 
    18 
    19 int main()
    20 {
    21 //    freopen("in.txt","r",stdin);
    22     int t,m,n,i,j;
    23     cin>>t;
    24     while(t--)
    25     {
    26         memset(map,0,sizeof(map));
    27         memset(visit,false,sizeof(visit));
    28         cin>>m>>n;
    29         for(i=1; i<=m; ++i)
    30             for(j=1; j<=n; ++j)
    31                 cin>>map[i][j];
    32         int k = 0;
    33         for(i=1; i<=m; ++i)
    34             for(j=1; j<=n; ++j)
    35                 if(map[i][j])
    36                 {
    37                     ++k;
    38                     //map[i][j] = 0;  上面的visit[]换成map[]也可以
    39                     dfs(i,j);
    40                 }
    41         cout<<k<<endl;
    42     }
    43     return 0;
    44 }
  • 相关阅读:
    剑指 Offer 03. 数组中重复的数字
    Leetcode_80: removeDuplicates
    Leetcode_27: removeElement
    Leetcode_26: removeDuplicates
    Leetcode-283: moveZeroes
    Module build failed: Error: Cannot find module 'node-sass’解决
    js实现简单的计算器
    根据经纬度显示地图、地图缩小偏移处理
    js实现滑动到屏幕底部
    【基础】在网页中嵌入页面
  • 原文地址:https://www.cnblogs.com/yaling/p/3040897.html
Copyright © 2011-2022 走看看