42. Trapping Rain Water
问题:
算储水量
思路:
源于http://blog.csdn.net/linhuanmars/article/details/20888505
储水的思路很简单, 要找到左右两个岸. 使用左右两个指针, 从左右同时开始向中间遍历, 直到终止条件. 比较左岸和右岸, 移动低的指针, 同时累计储水量.
code:
class Solution {
public:
int trap(vector<int>& height) {
int result = 0;
if (height.size() <= 2)
return result;
int left_cur = 0;
int right_cur = height.size()-1;
int left = height[left_cur];
int right = height[right_cur];
while(left_cur+1 < right_cur) { // 终止条件
if (left <= right) {
left_cur++;
if (left > height[left_cur])
result += (left-height[left_cur]);
else
left = height[left_cur];
} else {
right_cur--;
if (right > height[right_cur])
result += (right - height[right_cur]);
else
right = height[right_cur];
}
}
return result;
}
};