Post

Programmers_연습문제 가장 큰 정사각형 찾기(python)

프로그래머스 -가장 큰 정사각형 찾기 문제 입니다.

1. 문제

https://programmers.co.kr/learn/courses/30/lessons/12905


2. 분류 및 난이도

Programmers 문제입니다.
연습문제 문제입니다.

Level 2난이도의 문제입니다.


3. 생각한 것들(문제 접근 방법)

  • 재귀함수로 풀어야한다는 생각에 접근하지 못했습니다.
  • DP로 풀 수 있습니다.
  • 대각선, 바로 위의 열, 옆의 열을 검사하여 값을 갱신하면 됩니다.

4. 접근 방법을 적용한 코드

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
def solution(board):
    row = len(board)
    col = len(board[0])
    
    DP = [0] * row
    size = 0
    for i in range(row):
        DP[i] = [0] * col
    for i in range(row) : 
        for j in range(col) : 
            if i ==0 or j== 0 or board[i][j] == 0 : 
                DP[i][j] = board[i][j]
            else : 
                DP[i][j] = min(DP[i-1][j-1],min(DP[i-1][j],DP[i][j-1])) + 1
            size = max(size,DP[i][j])

    return size*size

5. 결과

필요시. c++ 짜드리겠습니다.

This post is licensed under CC BY 4.0 by the author.