forked from SamirPaulb/DSAlgo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
06. Maximal Rectangle.py
57 lines (47 loc) Β· 1.66 KB
/
06. Maximal 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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
# https://leetcode.com/problems/maximal-rectangle/
# https://youtu.be/tOylVCugy9k
class Solution:
def maximalRectangle(self, matrix: List[List[str]]) -> int:
if not matrix: return 0
arr = [0 for i in range(len(matrix[0]))]
ans = 0
for i in range(len(matrix)):
for j in range(len(matrix[0])):
if matrix[i][j] == "1":
arr[j] = arr[j] + 1
else: arr[j] = 0
ans = max(ans, self.largestRectangleArea(arr))
return ans
def largestRectangleArea(self, heights):
stack, lb = [], []
for i in range(len(heights)):
while stack:
if heights[stack[-1]] >= heights[i]:
stack.pop()
else:
lb.append(stack[-1] + 1)
stack.append(i)
break
if not stack:
stack.append(i)
lb.append(0)
stack, rb = [], []
for i in range(len(heights) - 1, -1, -1):
while stack:
if heights[stack[-1]] >= heights[i]:
stack.pop()
else:
rb.append(stack[-1] - 1)
stack.append(i)
break
if not stack:
stack.append(i)
rb.append(len(heights) - 1)
rb = rb[::-1]
res = 0
for i in range(len(heights)):
width = abs(lb[i] - rb[i]) + 1
res = max(res, width * heights[i])
return res
# Time: O(R * C)
# Space: O(C)