#include<bits/stdc++.h> using namespace std; int n,m,ans; char a[105][105]; int fx[12]={-2,-1,-1,-1,0,0,0,0,1,1,1,2}; int fy[12]={0,-1,0,1,-2,-1,1,2,-1,0,1,0}; void dfs(int x,int y){ for(int i=0;i<=11;i++){ int tx=x+fx[i]; int ty=y+fy[i]; if(tx>=1&&tx<=n&&ty>=1&&ty<=m&&a[tx][ty]=='#'){ a[tx][ty]='-'; dfs(tx,ty); } } } int main(){ cin>>n>>m; for(int i=1;i<=n;i++){ for(int j=1;j<=n;j++) cin>>a[i][j]; } for(int i=1;i<=n;i++){ for(int j=1;j<=n;j++){ if(a[i][j]=='#'){ ans++; a[i][j]=='-'; dfs(i,j); } } } cout<<ans; } /************************************************************** Problem: 1966 User: zhangzekai Language: C++ Result: Wrong Answer ****************************************************************/