-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsubarray_max_area_rectangle.py
32 lines (25 loc) · 1.14 KB
/
subarray_max_area_rectangle.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#
# 84. Largest Rectangle in Histogram
# https://leetcode.com/problems/largest-rectangle-in-histogram/
#
def largestAreaRectangle(heights: list[int]) -> int:
"""To get the max rectangle area, we need an effective data structure
to record all viable previous heights to heights[i] to form a larger rectangle.
1) Sliding Window & Stack
when iterate through heights, we can use a stack to record and accumulate
(i, h), where i is the start index where heights[i:j] > heights[j]
at each step we will unload all previous records that can form rectangle with height[j]
and calculate the area by (j-1-i+1)*height[i]
and then update the record with earliest index for height[j]
time complexity: O(N), space complexity: O(N)
"""
res, stack = 0, []
# append a 0 height to unload remaining stack in the end
for i, h in enumerate(heights + [0]):
left = i
# unload previous heights that can add current heights for rectangles
while stack and stack[-1][1] > h:
left, height = stack.pop()
res = max(res, (i - left) * height)
stack.append((left, h))
return res