题解 | #接雨水问题#

//接雨水问题 
//第一种比较直观
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * max water
     * @param arr int整型vector the array
     * @return long长整型
     */
    long long maxWater(vector<int>& arr) {
        
        long long res =0;
        int n =arr.size();
        vector<int> left(n+1);
        vector<int> right(n+1);
        int l_max=0,r_max=0;
        for(int i=0;i<n;i++)
        {
            l_max=max(l_max,arr[i]);
            left[i]=l_max;
        }
        for(int i=n-1;i>=0;i--)
        {
            r_max=max(r_max,arr[i]);
            right[i]=r_max;
        }
        for(int i=0;i<n;i++)
        {
            res+=min(left[i],right[i])-arr[i];
        }
        return res;
    }
};
//接雨水问题 
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * max water
     * @param arr int整型vector the array
     * @return long长整型
     */
    long long maxWater(vector<int>& arr) {
        
        long long res =0;
        int n =arr.size();
        int l_h=arr[0],r_h=arr[n-1];
        int l=0,r=n-1;
        while(l<=r)
        {
            r_h=max(r_h,arr[r]);
            l_h=max(l_h,arr[l]);
            if(l_h<r_h)
            {
                res+= l_h-arr[l];
                l++;
            }
            else if(l_h>r_h)
            {
                res+= r_h-arr[r];
                r--;
            }
            else {
                res+= l_h-arr[l];
                l++;
                if(l<=r)
                {
                    res+= l_h-arr[r];
                }
            }

        }
        return res;
    }
};


全部评论

相关推荐

不愿透露姓名的神秘牛友
07-04 18:02
好不容易拿到了字节Offer,鼠鼠做后端的,但家里人觉得可能被裁员不稳定,让鼠鼠去投国企,现在好纠结到底该咋选
文档传偷助手:该投就投吧,不过建议别放弃offer 拿到手里的才是最好的
投递字节跳动等公司8个岗位
点赞 评论 收藏
分享
06-10 23:36
已编辑
首都经济贸易大学 C++
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务