forked from sureshmangs/Code
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path42. Trapping Rain Water.cpp
76 lines (54 loc) · 1.63 KB
/
42. Trapping Rain Water.cpp
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
Given n non-negative integers representing an elevation map where the width of each bar is 1, compute how much water it is able to trap after raining.
The above elevation map is represented by array [0,1,0,2,1,0,1,3,2,1,2,1]. In this case, 6 units of rain water (blue section) are being trapped. Thanks Marcos for contributing this image!
Example:
Input: [0,1,0,2,1,0,1,3,2,1,2,1]
Output: 6
class Solution {
public:
int trap(vector<int>& a) {
int n=a.size();
if(n==0) return 0;
int maxl[n], maxr[n];
int maxi;
// cal maxl
maxi=a[0]; maxl[0]=a[0];
for(int i=0;i<n;i++){
if(a[i]>maxi){ maxi=a[i]; }
maxl[i]=maxi;
}
// cal maxr
maxi=a[n-1]; maxr[n-1]=a[n-1];
for(int i=n-1; i>=0; i--){
if(a[i]>maxi) { maxi=a[i]; }
maxr[i]=maxi;
}
int water[n];
long long waterTrap=0;
for(int i=0;i<n;i++){
water[i]=min(maxl[i], maxr[i])-a[i];
waterTrap+=water[i];
}
return waterTrap;
}
};
class Solution {
public:
int trap(vector<int>& height) {
int trapped=0;
int n=height.size();
int l=0, r=n-1;
int maxLeft=0, maxRight=0;
while(l<r){
if(height[l]>height[r]){
if(height[r]>maxRight) maxRight=height[r];
else trapped+=maxRight-height[r];
r--;
} else {
if(height[l]>maxLeft) maxLeft=height[l];
else trapped+=maxLeft-height[l];
l++;
}
}
return trapped;
}
};