#include<bits/stdc++.h>
using namespace std;
int m,n,ans;
char a[110][110];
bool f[110][110];
int dx[4]={0,1,0,-1};
int dy[4]={1,0,-1,0};
void dfs(int x,int y){
	    f[x][y]=true;
    for(int i=0;i<=3;i++){
        int tx=x+dx[i];
		int ty=y+dy[i];
        if(tx>0&&tx<=n&&ty>0&&ty<=m&&a[tx][ty]!='0'&&f[tx][ty]==false){
            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]!='0'&&f[i][j]==false){
				ans++;
				dfs(i,j);
			}
			
		}
	}
	cout<<ans;


	return 0;
}

/**************************************************************
	Problem: 1907
	User: hulaoshi
	Language: C++
	Result: Accepted
	Time:9 ms
	Memory:2440 kb
****************************************************************/