#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
const int maxn = 100 + 5;
char pic[maxn][maxn];
int m, n, idx[maxn][maxn];
void dfs(int r, int c, int id)
{
if(r<0 || r>=m || c<0 || c>=m) return;//出界
if(idx[r][c] > 0 || pic[r][c] != '1') return;//不是1或者已经访问了
idx[r][c] = id;//连通分量编号
for(int dr=-1; dr<=1; dr++)
for(int dc=-1; dc<=1; dc++)
if(dr!=0 || dc!=0) dfs(r+dr, c+dc, id);
}
int main()
{
while(scanf("%d", &m)==1 && m)
{
for(int i=0; i<m; i++)
scanf("%s", pic[i]);
memset(idx, 0, sizeof(idx));
int cnt = 0;
for(int i=0; i<m; i++)
for(int j=0; j<m; j++)
if(idx[i][j] == 0 && pic[i][j] == '1') dfs(i, j, ++cnt);
printf("%d\n", cnt);
}
return 0;
}
#include <cstdio>
#include <cstring>
using namespace std;
const int maxn = 100 + 5;
char pic[maxn][maxn];
int m, n, idx[maxn][maxn];
void dfs(int r, int c, int id)
{
if(r<0 || r>=m || c<0 || c>=m) return;//出界
if(idx[r][c] > 0 || pic[r][c] != '1') return;//不是1或者已经访问了
idx[r][c] = id;//连通分量编号
for(int dr=-1; dr<=1; dr++)
for(int dc=-1; dc<=1; dc++)
if(dr!=0 || dc!=0) dfs(r+dr, c+dc, id);
}
int main()
{
while(scanf("%d", &m)==1 && m)
{
for(int i=0; i<m; i++)
scanf("%s", pic[i]);
memset(idx, 0, sizeof(idx));
int cnt = 0;
for(int i=0; i<m; i++)
for(int j=0; j<m; j++)
if(idx[i][j] == 0 && pic[i][j] == '1') dfs(i, j, ++cnt);
printf("%d\n", cnt);
}
return 0;
}