Skip to content

LeetCode 64: Minimum Path Sum

Published: at 오후 04:20Suggest Changes

Table of contents

Open Table of contents

들어가며

이 문제는 움직일 수 있는 방향이 오른쪽과 아래 방향이어서 쉽게 DP 문제로 생각해 볼 수 있었습니다. 👍

AC 받은 Python 코드

from typing import List
import sys

input = sys.stdin.readline


class Solution:
    def minPathSum(self, grid: List[List[int]]) -> int:
        len_row = len(grid)
        len_col = len(grid[0])
        for i in range(len_row):
            for j in range(len_col):
                if i == 0 and j == 0:
                    continue

                if i == 0:
                    grid[i][j] = grid[i][j - 1] + grid[i][j]
                elif j == 0:
                    grid[i][j] = grid[i - 1][j] + grid[i][j]
                else:
                    grid[i][j] = min(grid[i - 1][j], grid[i][j - 1]) + grid[i][j]
        return grid[len_row - 1][len_col - 1]


if __name__ == "__main__":
    sol = Solution()
    grid = eval(input().rstrip())
    print(sol.minPathSum(grid))

Previous Post
C언어로 Worker Thread Pool 구현하기
Next Post
BOJ 백준 랜덤 디펜스