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];
}
};