LeetCode 64

https://leetcode.cn/problems/minimum-path-sum/description/

难度:中等

网格图 DP 题目。f 数组初始化为 INF,f[0][1] = 0。

f[i + 1][j + 1] = min(f[i + 1][j], f[i][j + 1]) + grid[i][j];

时间复杂度:O(mn),其中 m 和 n 分别为 grid 的行数和列数。

空间复杂度:O(mn)。

class Solution {
public:
    int minPathSum(vector<vector<int>>& grid) {
        int m = grid.size(), n = grid[0].size();
        vector f(m + 1, vector<int>(n + 1, INT_MAX));
        f[0][1] = 0;
        for (int i = 0; i < m; i++) {
            for (int j = 0; j < n; j++) {
                f[i + 1][j + 1] = min(f[i + 1][j], f[i][j + 1]) + grid[i][j];
            }
        }
        return f[m][n];
    }
};