*LeetCode-Trapping Rain Water

感觉很难想到 两个指针从两边 两边也都keep一个max 每次只挪动一个 根据当前那个低 就挪动那个 为了两个指针相遇的时候不会有冲突 而且相遇的时候也是低的一边决定水位

然后被挪动的一边判断当前高度和这边max的值 假如更高了 就update max, 否则就填一部分 填的是当前高度这个unit的上面和相应这边max之间的水

public class Solution {
    public int trap(int[] height) {
        int left = 0;
        int right = height.length - 1;
        int maxLeft = 0;
        int maxRight = 0;
        int res = 0;
        while ( left <= right ){
            if ( height [left] <= height [right] ){
                if ( height[ left ] > maxLeft )
                    maxLeft = height [ left ];
                else
                    res += maxLeft - height[left];
                left ++;
            }
            else {
                if ( height [ right ] > maxRight )
                    maxRight = height [ right ];
                else 
                    res += maxRight - height[right];
                right --;
            }
        }
        return res;
        
    }
}

还有一个办法是用stack 并没有研究明白


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值