42. Trapping Rain Water

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;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值