LeetCode 120

https://leetcode.cn/problems/triangle/description/

难度:中等

高频面试题汇总:https://www.yuweihung.com/posts/2025/lc-hot/

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

时间复杂度:O(n^2),其中 n 为 triangle 的长度。

空间复杂度:O(n^2)。

class Solution {
public:
    int minimumTotal(vector<vector<int>>& triangle) {
        int n = triangle.size();
        vector f(n, vector<int>(n));
        f[n - 1] = triangle[n - 1];
        for (int i = n - 2; i >= 0; i--) {
            for (int j = 0; j <= i; j++) {
                f[i][j] = min(f[i + 1][j], f[i + 1][j + 1]) + triangle[i][j];
            }
        }
        return f[0][0];
    }
};