力扣42.接雨水

力扣42.接雨水

前后缀数组

  • 对于每个一个位置

    • 求其前面最高高度pre_max[i] = max(pre_max[i-1] , h[i])
    • 和后面最高高度suf_max[i] = max(suf_max[i+1] , h[i])
    • 当前i处的水容量 为min(pre_max[i] , suf_max[i]) - h[i]
cpp 复制代码
  class Solution {
  public:
      int trap(vector<int>& height) {
          int n = height.size();
          vector<int> pre_max(n),suf_max(n);
          pre_max[0] = height[0];
          suf_max[n-1] = height[n-1];
          for(int i=1;i<n;i++)
              pre_max[i] = max(pre_max[i-1],height[i]);
          for(int i=n-2;i>=0;i--)
              suf_max[i] = max(suf_max[i+1],height[i]);
          
          int res=0;
          for(int i=0;i<n;i++)
              res += min(pre_max[i],suf_max[i]) - height[i];
  
          return res;
      }
  };

双指针

  • 考虑不用数组存pre_max和suf_max而改用实时更新

    • 每到达一个位置时 更新pre_max和suf_max
    • 若pre_max < suf_max 说明当前水容量为 pre_max(小的) - h[i]
    • 反之亦然
cpp 复制代码
  class Solution {
  public:
      int trap(vector<int>& height) {
          int n = height.size();
          int l = 0,r = n-1;
          int res=0;
          int pre_max = 0,suf_max = 0;
          while(l <= r)
          {
              pre_max = max(pre_max,height[l]);
              suf_max = max(suf_max,height[r]);
              if(pre_max < suf_max)
              {
                  res += pre_max - height[l];
                  l ++;
              }
              else
              {
                  res += suf_max - height[r];
                  r --;
              }
          }
          return res;
      }
  };
相关推荐
御风@户外23 分钟前
质数生成函数、质数判断备份
算法·acm
Cosmoshhhyyy25 分钟前
LeetCode:3083. 字符串及其反转中是否存在同一子字符串(哈希 Java)
java·leetcode·哈希算法
闻缺陷则喜何志丹36 分钟前
【C++动态规划】1105. 填充书架|2104
c++·算法·动态规划·力扣·高度·最小·书架
Dong雨1 小时前
六大排序算法:插入排序、希尔排序、选择排序、冒泡排序、堆排序、快速排序
数据结构·算法·排序算法
达帮主1 小时前
7.C语言 宏(Macro) 宏定义,宏函数
linux·c语言·算法
是十一月末1 小时前
机器学习之KNN算法预测数据和数据可视化
人工智能·python·算法·机器学习·信息可视化
chenziang11 小时前
leetcode hot100 路径总和
算法
lyx1426061 小时前
leetcode 3083. 字符串及其反转中是否存在同一子字符串
算法·leetcode·职场和发展
茶猫_1 小时前
力扣面试题 39 - 三步问题 C语言解法
c语言·数据结构·算法·leetcode·职场和发展
初学者丶一起加油1 小时前
C语言基础:指针(数组指针与指针数组)
linux·c语言·开发语言·数据结构·c++·算法·visual studio