#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]=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++) ss[i][j]=999999;
	}
	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
****************************************************************/