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;
    }
};
相关推荐
QiLinkOS3 小时前
第三视觉理解徐玉生与他的商业活动(30)
大数据·c++·人工智能·算法·开源协议
疯狂打码的少年3 小时前
【操作系统】页面置换算法(OPT/FIFO/LRU)
算法
小O的算法实验室3 小时前
2026年CIE,优化客货协同运输:综合地铁系统的列车容量动态分配
算法
Coder_Shenshen4 小时前
西门子S7CommPlus协议鉴权算法原理与流程详解
网络·后端·算法
硕风和炜5 小时前
【LeetCode: 2492. 两个城市间路径的最小分数 + DFS】
java·算法·leetcode·深度优先·dfs·bfs·并查集
我是一颗柠檬6 小时前
【Java项目技术亮点】加权轮询负载均衡算法
java·算法·负载均衡
灯厂码农6 小时前
C语言动态内存分配完全指南(malloc、calloc、realloc、free)
java·c语言·算法
凯瑟琳.奥古斯特7 小时前
K次取反最大化数组和解法(力扣1005)
开发语言·c++·算法·leetcode·职场和发展
Jerry8 小时前
LeetCode 203. 移除链表元素
算法
地平线开发者8 小时前
征程 6 | 工具链 QAT ObserverBase 源码解析
算法