백준
백준 6549 히스토그램에서 가장 큰 직사각형 (파이썬)
MC류짱
2022. 11. 13. 13:52
풀이
import sys;
while True:
N, *info = map(int, sys.stdin.readline().strip().split())
if N == 0:
break
info.append(0)
S = []
rst = 0
for i in range(N+1):
# 스택에 높이와 인덱스를 저장할건데 pointer는 인덱스를 가리킴
# 이때 저장하는 인덱스는 단순히 그 높이의 인덱스가 아니라 현재 높이로 만들수 있는 전의 인덱스를 가르킴
pointer = i
# 현재 높이가 스택에 마지막 요소의 높이보다 작으면 rst값을 갱신
while S and info[i] < S[-1][0]:
h, d = S.pop()
# 이때 포인터를 d로 가르키게함 자세한 설명은 후기에..
pointer = d
tmp = h * (i-d)
rst = max(rst, tmp)
S.append((info[i], pointer))
print(rst)
후기
- 플레인데 쉬워보여서 도전한 문제
- 처음엔 단순히 2중 for문 돌려서 구할 수는 있었지만, 시간 초과가 남
- for문 안에 for문이 아닌 while문을 돌려서 조건을 비교할 수 있는지 연산을 줄여줌
- 근데 첫 풀이는 틀렸다는 채점결과가 계속 나옴
- 이유는 처음엔 S에 (info[i], i)로 넣어주어서 3 2 3 4 5 1 이런 경우에 높이가 2인 경우 스택에 (2, 1)을 넣어줬는데,
- (2, 0)을 넣어줬어야함 그래서 pointer라는 변수를 추가해서 인덱스를 바꿔 스택에 저장