문제링크:https://www.acmicpc.net/problem/6549
다루는 주제: 분할정복
import sys
def histo(arr, start, end):
if start == end:
return arr[start]
else:
mid = (start + end) // 2
width = 2 # 너비
left = mid # 경계 왼쪽
right = mid + 1 # 경계 오른쪽
min_height = min(arr[left], arr[right]) # 둘 중에 작은 값
big_square = min_height * 2 # 경계를 두고 정해지는 직사각형의 크기
while True:
if (arr[left] == 0 or left == start) and (arr[right] == 0 or right == end):
# 왼쪽, 오른쪽 경계값이 0이거나 더이상 이동할수없을떄
break
elif arr[left] == 0 or left == start: # 왼쪽으로 이동할수없을떄
if arr[right + 1] < min_height:
min_height = arr[right + 1]
right += 1
elif arr[right] == 0 or right == end: # 오른쪽으로 이동할수없을때
if arr[left - 1] < min_height:
min_height = arr[left - 1]
left -= 1
else: # 왼쪽 오른쪽 모두 이동 가능 할 경우
if arr[left - 1] > arr[right + 1]: # 왼쪽 값이 더 크고
if arr[left - 1] < min_height: # min_height 보다 값이 작으면
min_height = arr[left - 1] # min_height를 갱신해준다
left -= 1 # 다시 이동
else: # 오른쪽 값이 더 크고
if arr[right + 1] < min_height: # min_height보다 값이 작으면
min_height = arr[right + 1] # 갱신
right += 1
width += 1
big_square = max(big_square, min_height * width) # 기존의 big_square와 갱신된 넓이 비교
return max(histo(arr, start, mid), histo(arr, mid + 1, end), big_square)
while True:
square = list(map(int, sys.stdin.readline().split()))
if square[0] == 0:
break
print(histo(square, 1, len(square) - 1))
'Algorithm > 백준(파이썬)' 카테고리의 다른 글
백준 2493 파이썬(Python) 문제풀이 탑 (0) | 2023.04.19 |
---|---|
백준 10830 파이썬(Python) 문제풀이 행렬제곱 (0) | 2023.04.17 |
백준 1629 파이썬(Python) 문제풀이 곱셈 (0) | 2023.04.16 |
백준 2630 파이썬(Python) 문제풀이 색종이 만들기 (0) | 2023.04.16 |
백준 8983 파이썬(Python) 문제풀이 사냥꾼 (0) | 2023.04.16 |