-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathTrapping Rain water.py
57 lines (40 loc) · 1.12 KB
/
Trapping Rain water.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
# Python implementation of the approach
# Function to return the maximum
# water that can be stored
def maxWater(height):
# Stores the indices of the bars
stack = []
# size of the array
n = len(height)
# Stores the final result
ans = 0
# Loop through the each bar
for i in range(n):
# Remove bars from the stack
# until the condition holds
while(len(stack) != 0 and (height[stack[-1]] < height[i])):
# store the height of the top
# and pop it.
pop_height = height[stack[-1]]
stack.pop()
# If the stack does not have any
# bars or the popped bar
# has no left boundary
if(len(stack) == 0):
break
# Get the distance between the
# left and right boundary of
# popped bar
distance = i - stack[-1] - 1
# Calculate the min. height
min_height = min(height[stack[-1]], height[i])-pop_height
ans += distance * min_height
# If the stack is either empty or
# height of the current bar is less than
# or equal to the top bar of stack
stack.append(i)
return ans
# Driver code
if __name__ == '__main__':
arr = [0, 1, 0, 2, 1, 0, 1, 3, 2, 1, 2, 1]
print(maxWater(arr))