[LeetCode]Minimum Path Sum

2023. 5. 25. 19:32·SW개발/코딩테스트

https://leetcode.com/problems/minimum-path-sum/

 

Minimum Path Sum - LeetCode

Can you solve this real interview question? Minimum Path Sum - Given a m x n grid filled with non-negative numbers, find a path from top left to bottom right, which minimizes the sum of all numbers along its path. Note: You can only move either down or rig

leetcode.com

 

문제 분석

주어진 m*n grid에서 오른쪽 or 아래로만 이동할 수 있습니다. 가장 왼쪽 위에서 가장 오른쪽 아래로 이동하는 경로의 합이 가장 적은 값을 구하는 문제입니다.

 

처음 시도한 답안

class Solution:
    def minPathSum(self, grid: List[List[int]]) -> int:
        for row_idx, row in enumerate(grid):
            for col_idx, col in enumerate(row):
                if row_idx != 0 and col_idx != 0:
                    grid[row_idx][col_idx] = min(grid[row_idx-1][col_idx], grid[row_idx][col_idx-1]) + grid[row_idx][col_idx]
                else:
                    if row_idx == 0 and col_idx == 0:
                        continue

                    if row_idx == 0:
                        grid[row_idx][col_idx] = grid[row_idx][col_idx-1] + grid[row_idx][col_idx]

                    if col_idx == 0:
                        grid[row_idx][col_idx] = grid[row_idx-1][col_idx] + grid[row_idx][col_idx]

        return grid[-1][-1]

접근 방법

  1. grid를 이중 순회합니다. 
  2. (0, 0) 지점이 아니라면
    1. (i-1, j), (i, j-1) 중 작은 값과 현재 값을 더해서 grid를 갱신합니다.
  3. (0, 0) 지점이라면 건너뜁니다.
  4. row_idx만 0이라면 
    1. (i, j-1)에 현재 값을 더해서 grid를 갱신합니다.
  5. col_idx만 0이라면
    1. (i-1, j)에 현재 값을 더해서 grid를 갱신합니다.
  6. 가장 오른쪽 아래에 위치한 값이 최소 값입니다.

이 문제는 DP 문제입니다. Grid를 보고 각 좌표에서의 최소 합을 구해보다보면 일종의 규칙을 찾을 수 있습니다.

(x, y) 위치까지 오기위한 최소 값은 (x-1, y) + (x, y) 와 (x, y-1) + (x, y) 중 더 작은 값을 고르면 됩니다. 그리고 0이 들어가는 인덱스의 경우에는 따로 예외처리를 해주면서 반복문을 순회하면 최소 합을 구할 수 있습니다.

 

728x90

'SW개발 > 코딩테스트' 카테고리의 다른 글

[LeetCode]Search a 2D Matrix  (0) 2023.05.27
[LeetCode]Set Matrix Zeroes  (0) 2023.05.26
[LeetCode]Jump Game  (0) 2023.05.24
[LeetCode]Spiral Matrix II  (0) 2023.05.23
[LeetCode]Spiral Matrix  (0) 2023.05.22
'SW개발/코딩테스트' 카테고리의 다른 글
  • [LeetCode]Search a 2D Matrix
  • [LeetCode]Set Matrix Zeroes
  • [LeetCode]Jump Game
  • [LeetCode]Spiral Matrix II
Leffe_pt
Leffe_pt
개발자로서 성장하면서 배워온 지식과 경험을 공유하는 공간입니다.
  • Leffe_pt
    Leffe's tistory
    Leffe_pt
  • 전체
    오늘
    어제
    • 분류 전체보기 (309)
      • SW개발 (305)
        • 코딩테스트 (172)
        • 개발이야기 (23)
        • IT 용어 (17)
        • Python (22)
        • Django (46)
        • Flask (2)
        • Database (3)
        • SQLAlchemy (0)
        • Javascript (5)
        • Linux, Unix (3)
        • JAVA (2)
        • Spring (10)
      • 회고 (4)
      • 사진 (0)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    배공파용
    음식
    컨트리뷰터
    배달비 공유
    Contributor
    g
    오픈소스
    django
    플레이스토어
    배달
    어플리케이션
    라이프 스타일
    트리 #AVL #알고리즘 #자료구조
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
Leffe_pt
[LeetCode]Minimum Path Sum
상단으로

티스토리툴바