#include <cstdio>
int n,Map[1005][1005],v = 0,r = 0,tmp,dx[] = {0,0,1,-1,1,1,-1,-1},dy[] = {1,-1,0,0,1,-1,1,-1},sw;
bool vis[1005][1005] = {false},flag = true;
bool cp(int x,int y){
return !(x < 0 || x >= n || y < 0 || y >= n || vis[x][y] == true);
}
void dfs(int x,int y){
if(vis[x][y]) return;
vis[x][y] = true;
for(int i = 0; i < 8; i++){
int nx = x + dx[i],ny = y + dy[i];
if(cp(nx,ny)){
if(Map[x][y] == Map[nx][ny]){
dfs(nx,ny);
}
if(Map[x][y] > Map[nx][ny]){
sw = 1;
}
if(Map[x][y] < Map[nx][ny]){
sw = 2;
}
}
}
return;
}
void SCAN(int i,int j){
int a;
scanf("%d",&a);
if(i == 0 && j == 0) tmp = a;
if(a != tmp) flag = false;
Map[i][j] = a;
return;
}
int main(){
scanf("%d",&n);
for(int i = 0; i < n; i++) for(int j = 0; j < n; j++) SCAN(i,j);
if(flag){
printf("1 1");
return 0;
}
for(int i = 0; i < n; i++) for(int j = 0; j < n; j++){
if(vis[i][j]) continue;
dfs(i,j);
switch(sw){
case 1:
r++;
break;
case 2:
v++;
break;
}
}
printf("%d %d",r,v);
return 0;
}