Skip to content

Latest commit

 

History

History
26 lines (19 loc) · 591 Bytes

120.Triangle.md

File metadata and controls

26 lines (19 loc) · 591 Bytes

120. Triangle

Difficulty: Medium

URL

https://leetcode.com/problems/triangle/

Solution

Approach 1: Dynamic Programming

The code is shown below:

class Solution:
    def minimumTotal(self, triangle: List[List[int]]) -> int:
        n = len(triangle)
        dp = [[float('inf')] * n for _ in range(n)]
        dp[0][0] = triangle[0][0]
        for i in range(1, n):
            dp[i][0] = triangle[i][0] + dp[i-1][0]
            for j in range(1, i + 1):
                dp[i][j] = triangle[i][j] + min(dp[i-1][j], dp[i-1][j-1])
        return min(dp[n-1])