#include<bits/stdc++.h>
using namespace std;
int n,m,a[35][35],ss[35][35];
int fx[4]={0,1,0,-1},fy[4]={1,0,-1,0};
bool v[35][35];
void bfs(int x,int y,int s){
s+=a[x][y];
v[x][y]=1;
if(s<ss[x][y]||ss[x][y]==0) ss[x][y]=s;
for(int i=0;i<4;i++){
int tx=x+fx[i],ty=y+fy[i];
if(tx>=1&&tx<=n&&ty>=1&&ty<=m&&v[tx][ty]!=1){
bfs(tx,ty,s);
}
}
v[x][y]=0;
}
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++) cin>>a[i][j];
}
bfs(1,1,0);
cout<<ss[n][m];
return 0;}
/**************************************************************
Problem: 1541
User: fzy001
Language: C++
Result: Time Limit Exceed
****************************************************************/