#include<cstdio>
#include<iostream>
#include<queue>
using namespace std;
int n,m,sum=0;
char s;
int a[101][101];//标记数组
int dx[4]={0,0,1,-1};//四个方位
int dy[4]={1,-1,0,0};
struct node
{
int x,y;
}now;
void bfs(int x,int y)
{
queue<node> q;
q.push({x,y});//讲初始点的入队
while(!q.empty())
{
now=q.front();//当前的点
q.pop();
for(int i=0;i<4;i++)
{
int xx=now.x+dx[i];//往当前点的各个方向前进
int yy=now.y+dy[i];
if(xx>=1&&xx<=n&&yy>=1&&yy<=m&&a[xx][yy])
{//未越界且是细胞
a[xx][yy]=0;//标记
q.push({xx,yy});//过完了之后放入队尾
}
}
}
}
int main()
{
cin>>n>>m;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
cin>>s;
a[i][j]=s-'0';//转换
}
}
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
if(a[i][j]!=0)//是细胞
{
a[i][j]=0;//标记
bfs(i,j);
sum++;
}
}
}
cout<<sum;
return 0;
}