#include <iostream>
#include <vector>
using namespace std;

int main() {
    int n,m;cin>>n>>m;
    vector<vector<int>> matrix(n+1,vector<int>(m+1,0));

    //输入元素
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            cin>>matrix[i][j];
        }
    }

    //动态规划求解
    vector<vector<int>> dp(n+1,vector<int>(m+1,0));
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            if(i==1) dp[i][j] = matrix[1][j]+dp[1][j-1];
            else if(j==1) dp[i][j] = matrix[i][1]+dp[i-1][j];
            else
            {
                dp[i][j] = min(dp[i-1][j],dp[i][j-1]) + matrix[i][j];   //状态转移方程
            }
        }
    }

    cout<<dp[n][m]<<endl;
}
// 64 位输出请用 printf("%lld")