#include <bits/stdc++.h>
using namespace std;
int n,m,ans,fx[4]={0,1,0,-1},fy[4]={1,0,-1,0};
char a[505][505];
void dfs(int x,int y){//x----i y----j
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') ans++;
}
}
//输出个数
cout<<ans;
return 0;
}
/**************************************************************
Problem: 1913
User: chenhongen
Language: C++
Result: Accepted
Time:37 ms
Memory:2324 kb
****************************************************************/