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;
    }
};
相关推荐
水木流年追梦1 小时前
大模型入门-大模型的推理策略
开发语言·python·算法·正则表达式·prompt
生成论实验室1 小时前
用事件关系网络重新理解AI(三):激活函数、微调与元学习
人工智能·学习·算法·语言模型·可信计算技术
Narv工程师1 小时前
嵌入式机器人控制器算力评估:从DMIPS到WCET的完整指南
人工智能·算法·机器学习
蒟蒻的贤1 小时前
实训1227
算法
liulilittle2 小时前
TCP UCP:基于卡尔曼滤波的BBR增强型拥塞控制算法
linux·网络·c++·tcp/ip·算法·c·通讯
LCG元2 小时前
RAG - 大模型检索增强生成深度解析:本地知识库 / 企业级落地优化配置
人工智能·算法
龙佚2 小时前
RTC语音质量优化实战:搭建完整语音系统
算法·架构
过期动态2 小时前
【LeetCode 热题 100】字母异位分组
java·算法·leetcode·职场和发展·哈希算法
Cthy_hy2 小时前
Python 算法竞赛:数学核心知识点全总结
python·算法