#include <bits/stdc++.h>
using namespace std;
int n,m;int sum=0;
char a[105][105];
int vis[105][105];
int dx[6]={0,-1,0,1,0};
int dy[654]={0,0,-1,1,1};
struct node{
int left,right;
};
void bfs(int x,int y){
queue<node> q;
q.push((node){x,y});
vis[x][y]=2;
while(!q.empty()){
node now=q.front();
q.pop();
for(int i=1;i<=4;i++){
int tx=now.left+dx[i];
int ty=now.right+dy[i];
if(vis[tx][ty]==2)return;
if(tx>n||ty>n||tx<0||ty<0)return;
if(a[tx][ty]==a[now.left][now.right])return;
sum++;vis[tx][ty]=2;
}
}
}
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
cin>>a[i][j];
}
}
for(int i=1;i<=m;i++){
int qwq,pwp;
cin>>qwq>>pwp;
bfs(qwq,pwp);
cout<<sum<<" ";
sum=0;
}
return 0;
}