[프로그래머스] Level2, 가장 큰 정사각형 찾기 (Python)

2021. 6. 8. 23:56·알고리즘/프로그래머스
728x90
반응형

문제

https://programmers.co.kr/learn/courses/30/lessons/12905?language=python3 

 

코딩테스트 연습 - 가장 큰 정사각형 찾기

[[0,1,1,1],[1,1,1,1],[1,1,1,1],[0,0,1,0]] 9

programmers.co.kr

 

코드

def solution(board):
    answer = 0
    for i in range(1,len(board)):
        for j in range(1, len(board[0])):
            if board[i][j] == 1:
                board[i][j] = min(board[i-1][j-1], board[i-1][j], board[i][j-1]) + 1
    return max([j for i in board for j in i])**2

DP를 이용하여 정사각형 변의 길이를 누적해서 리스트에 넣은다음에 가장 큰 수를 찾아 넓이를 구하면 된다.

0번째 행과열은 누적하기 위해서 기본 값으로 두고 1부터 시작한다.

 

board[i][j]가 1인 경우 왼쪽, 위쪽, 대각선 위쪽을 확인하여 가장 작은 값에 +1을 해준값을 board[i][j]에 채워준다.

min으로 해주는 이유는 한개라도 0이거나 다른 수 보다 작다면 정사각형이 아니기 때문에 min을 이용해 구해준다.

 

0 1 1 1                 

1 1 1 1      

1 1 1 1

0 0 1 0

 

board[1][1]부터 확인한다 board[0][0]이 0으로 최솟값이므로 +1 한 값인 1이 board[1][1]에 들어간다.

다음으로 board[1][2]는 왼쪽, 대각선 위쪽, 위쪽 모두 1이므로 +1 한 2값이 들어가게 되어서 변의 길이가 2인 정사각형을 만들 수 있게 된다.

 

쭉쭉 하다보면 ...

 

0 1 1 1

1 1 2 2

1 2 2 3

0 1 2 3

 

이런식으로 되어서 최대 변의길이가 3인 정사각형을 만들수 있게 된다.

 

그리고 return에 for문은 2중 for문 돈 뒤에 리스트에 append하는 과정을 축약 해놓은 것이다.

반응형
저작자표시 (새창열림)

'알고리즘 > 프로그래머스' 카테고리의 다른 글

[프로그래머스] Level2, 이진 변환 반복하기 (Python)  (0) 2021.06.09
[프로그래머스] Level2, 영어 끝말잇기 (Python)  (0) 2021.06.09
[프로그래머스] Level2, 올바른 괄호 (Python)  (0) 2021.06.08
[프로그래머스] Level2, 땅따먹기 (Python)  (0) 2021.06.08
[프로그래머스] Level2, 최솟값 만들기 (Python)  (0) 2021.06.08
'알고리즘/프로그래머스' 카테고리의 다른 글
  • [프로그래머스] Level2, 이진 변환 반복하기 (Python)
  • [프로그래머스] Level2, 영어 끝말잇기 (Python)
  • [프로그래머스] Level2, 올바른 괄호 (Python)
  • [프로그래머스] Level2, 땅따먹기 (Python)
wookcode
wookcode
공부한 내용들을 정리하고 기록하는 블로그입니다.
    반응형
  • wookcode
    wookcode
    wookcode
  • 전체
    오늘
    어제
    • 카테고리 (196) N
      • study (1) N
        • 아파치 카프카 애플리케이션 프로그래밍 with 자.. (0)
        • 인프런 (1) N
      • Live Study (15)
      • Programming (14)
        • Java (8)
        • Python (1)
        • Springboot (5)
        • MSA (0)
      • 알고리즘 (117)
        • 백준 (58)
        • 프로그래머스 (59)
      • 에러로그 (5)
      • 항해99 (23)
      • 면접 (1)
      • 프로젝트 (1)
      • CS (19)
        • 네트워크 (2)
        • 운영체제 (2)
        • 데이터베이스 (2)
        • 컴퓨터구조 (1)
        • Java (8)
        • Spring (4)
  • 블로그 메뉴

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

  • 공지사항

  • 인기 글

  • 태그

    회고
    카카오코딩테스트
    괄호
    파이썬
    java
    해결
    미니프로젝트
    spring
    SFlash
    카카오인턴
    인프런
    항해99
    스파르타코딩클럽
    orm
    정리
    조합
    실전프로젝트
    항해마켓
    코딩테스트
    jpa
    버그
    그리디
    에러
    SpringBoot
    프로그래머스
    백준
    알고리즘
    김영한
    브루트포스
    후기
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.4
wookcode
[프로그래머스] Level2, 가장 큰 정사각형 찾기 (Python)
상단으로

티스토리툴바