#include<bits/stdc++.h>
using namespace std;
int n,m,sum=0;
char a[505][505];
int fx[4]={0,1,0,-1};
int fy[4]={1,0,-1,0};
void dfs(int x,int y){//x----i y----i
for(int i=0;i<=3;i++){//4次
int tx=x+fx[i];//tx就是x要向4个方向进行搜索的x坐标,i;
int ty=y+fy[i];//ty就是y要向4个方向进行搜索的y坐标,j;
if(tx>=1 && tx<=n && ty>=1 && ty<=m && a[tx][ty]=='0'){
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((i==1 || i==n || j==1 || j==m) && a[i][j]=='0'){
a[i][j]='*';//i,j这个点被我走过了,所以要标记掉
dfs(i,j);//i,j走过的这个点 ,进行4个方向的搜索
}
}
}
//统计指挥部没被淹没到的重要区域(由"0"表示)有多少
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
if(a[i][j]=='0'){
sum++;
}
}
}
//输出个数
cout<<sum;
return 0;
}
/**************************************************************
Problem: 1913
User: guoyixuan
Language: C++
Result: Accepted
Time:42 ms
Memory:2324 kb
****************************************************************/