#include<bits/stdc++.h>
using namespace std;
int n,cnt;
bool tag[100][100];
int dir[][2]={
{
1,0},{
0,-1},{
-1,0},{
0,1}};
int print[100][2];
void dfs(int x,int y,int k)
{
if(x==n&&y==n){
cnt++;
for(int i=0;i<k;i++){
cout<<'('<<print[i][0]<<','<<print[i][1]<<')';
if(i==k-1)
cout<<endl;
}
return ;
}
for(int i=0;i<4;i++){
int ix=x+dir[i][0];
int iy=y+dir[i][1];
if(tag[ix][iy]||ix<1||iy<1||ix>n||iy>n){
continue;
}
print[k][0]=ix;
print[k][1]=iy;
tag[ix][iy]=true;
dfs(ix,iy,k+1);
tag[ix][iy]=false;
}
}
int main(){
cin>>n;
tag[1][1]=true;
print[0][0]=1;
print[0][1]=1;
dfs(1,1,1);
cout<<cnt;
}
#include<bits/stdc++.h>
using namespace std;
int dir[][2]={
{
1,0},{
-1,0},{
0,1},{
0,-1}};
int n,m;
const int N=100;
int map1[N][N];
struct node{
int x;
int y;
};
queue<node> que;
int foot[N][N];
int bfs(){
que.push({
0,0});
foot[0][0]=0;
while(que.size()){
node temp=que.front();
que.pop();
for(int i=0;i<4;i++){
int ix=temp.x+dir[i][0];
int iy=temp.y+dir[i][1];
if(ix<0||iy<0||ix>=n||iy>=m||foot[ix][iy]!=-1||map1[ix][iy]==1){
continue;
}
que.push({
ix,iy});
foot[ix][iy]=foot[temp.x][temp.y]+1;
if(ix==n-1&&iy==m-1){
return foot[ix][iy];
}
}
}
}
int main(){
cin>>n>>m;
for(int i=0;i<n;i++){
for(int j=0;j<m;j++){
cin>>map1[i][j];
}
}
memset(foot,-1,sizeof(foot));
cout<<bfs()<<endl;
}