题解 | #接雨水问题#

接雨水问题

https://www.nowcoder.com/practice/31c1aed01b394f0b8b7734de0324e00f

基本思路:使用双指针向中间逼近即可
1.使用双指针
2.使用两个值记录下双指针的左右值,同时如果遇到比自己大,则必须更新当前值,用于计算结果
class Solution {
public:
    long long maxWater(vector<int>& arr) {
        // write code here
        //基本思路,就是两边开始,由低的往高处找,遇到比自己更高的就更新当前值,遇到比自己低的就
        //计算当前可以成的雨水数
        int size = arr.size();
        int left = 0;
        int right = size - 1;
        long long res = 0;//记录最后的结果,也即雨水值
        long long templ = arr[left];//记录左指针的值,指针会一直更新,但是templ必须要遇到更大的值才更新
        long long tempr = arr[right];//记录右指针的值
        
        //如果是遇到left刚好等于right- 1,此时不会影响最后的结果,所以这里用的是left < right - 1
        while(left < right - 1)
        {
            //当左边维护的值小于右边维护的值
            if(templ < tempr)
            {
                left++;//自加
                //如果left指针指向的值小于之前维护的值,则说明可以接到雨水
                if(arr[left] <= templ)
                {
                    res += (templ - arr[left]);
                }
                //接不到雨水,则更新自己的左值
                else{
                    templ = arr[left];
                }
                
            }
            else
            {
                right--;
                if(arr[right] <= tempr)
                {
                    res += (tempr - arr[right]);
                }
                else{
                    tempr = arr[right];
                }
            }
        }
        return res;
    }
};


全部评论

相关推荐

想申请延毕了,找工作找到崩溃,越找就越想摆烂,还有25届的和我一样感受吗?
码农索隆:没事哒,好兄弟,慢慢来,调整心态,车到山前必有路,感到迷茫的时候,多抬头看看
点赞 评论 收藏
分享
04-18 15:58
已编辑
门头沟学院 设计
kaoyu:这一看就不是计算机的,怎么还有个排斥洗碗?
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务