#include<bits/stdc++.h>
using namespace std;
//
//-#----
//##----
//--##--
//------
//-#----
//--#-##
//
// 从第一个找到最后一个#
// 当找到一个的时候,答案+1
// 并且开启搜索,搜索他附近的12个位置是否有#
// 如果有#就把他变为-
//
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<+m;j++) cin>>a[i][j];
}
for(int i=1;i<=n;i++){
for(int j=1;j<+m;j++){
if(a[i][j]=='#'){
ans++;
a[i][j]=='-';
dfs(i,j);
}
}
}
cout<<ans;
}
/**************************************************************
Problem: 1966
User: admin
Language: C++
Result: Wrong Answer
****************************************************************/