leetcode42雨水

题目链接:https://leetcode.cn/problems/trapping-rain-water/description/?envType=study-plan-v2\&envId=top-100-liked

法一:前缀和

求能装多少水,即左右两边木板高度的最小值减去数组元素。左边木板高度即左区间最大高度,右边木板高度即右区间最大高度。第一个数组存储从最左边到第i个位置的最大高度(前缀最大值),第二个数组存储从最右边到第i的位置的最大高度(后缀最大值)。对于当前位置的前缀最大值 = max(前一个位置的前缀最大值,当前位置的最大高度)。每一个位置的前后缀数组里的值的最小值减去数组中的数值即水

cpp 复制代码
class Solution {
    int pre_max[20010];
    int suf_max[20010];
public:
    int trap(vector<int>& nums) {
        int n = nums.size();
        pre_max[0] = nums[0];
        for (int i = 1; i < n; ++i)
            pre_max[i] = max(pre_max[i - 1], nums[i]);
        
        suf_max[n - 1] = nums[n - 1];
        for (int i = n - 2; i >= 0; --i)
            suf_max[i] = max(suf_max[i + 1], nums[i]);
        
        int ret = 0;
        for (int i = 0; i < n; ++i)
        {
            ret += min(pre_max[i], suf_max[i]) - nums[i];
        }
        return ret;

        
    }
};

法二:优化为双指针(好处,不用创建数组)

前缀最大值 > 后缀最大值,则最大高度为后缀最大值,水量为这个最大高度减去数组元素,右指针左移

cpp 复制代码
class Solution {
public:
    int trap(vector<int>& nums) {
        int n = nums.size();
        int pre_max = 0, suf_max = 0;
        int left = 0, right = n  - 1;
        int ret = 0;

        while (left <= right)
        {
            pre_max = max(pre_max, nums[left]);
            suf_max = max(suf_max, nums[right]);

            if (pre_max < suf_max)
            {
                ret += pre_max - nums[left++];
            }
            else ret += suf_max - nums[right--];
        }
        return ret;
    }
};
相关推荐
IronMurphy20 分钟前
【算法五十七】146. LRU 缓存
算法·缓存
凌波粒1 小时前
LeetCode--108.将有序数组转换为二叉搜索树(二叉树)
算法·leetcode·职场和发展
liulilittle1 小时前
KCC:在 BBR 思路上的一次探索
网络·tcp/ip·算法·bbr·通信·拥塞控制·kcc
浦信仿真大讲堂1 小时前
达索系统SIMULIA Abaqus 2026接触和约束的增强新功能介绍
人工智能·python·算法·仿真软件·达索软件
点云侠1 小时前
PCL 生成三棱锥点云
c++·算法·最小二乘法
兰令水2 小时前
leecodecode【面试150】【2026.6.13打卡-java版本】
java·算法·leetcode
临沂堇2 小时前
刷题日志 | Leetcode Hot 100 哈希
算法·leetcode·哈希算法
玉小格2 小时前
一次关于Python的总结
算法
伊甸32 小时前
从企业级项目学敏感词过滤:DFA算法与双层缓存实战
java·算法·缓存
bIo7lyA8v2 小时前
算法中的随机化思想及其复杂度收益评估的技术8
算法