【双指针】接雨水

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨

示例 1:

复制代码
 输入:height = [0,1,0,2,1,0,1,3,2,1,2,1]
 输出:6
 解释:上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下,可以接 6 个单位的雨水(蓝色部分表示雨水)。 

示例 2:

复制代码
 输入:height = [4,2,0,3,2,5]
 输出:9
复制代码
 class Solution {
 public:
     int trap(vector<int>& height) {
         int sum = 0;
         for(int i = 0;i<height.size();i++){
             // 第一个柱子和最后一个柱子不接雨水
             if (i == 0 || i == height.size() - 1) continue;
             int rHeight = height[i];//右边高的
             int lHeight = height[i];//左边高的
             for(int r = i+1;r<height.size();r++){
                 if(rHeight<height[r]){
                     rHeight = height[r];
                 }
             }
             for(int l = i-1;l>=0;l--){
                 if(height[l]>lHeight) lHeight = height[l];
             }
             int h = min(lHeight,rHeight) - height[i];
             if(h>0) sum+=h;
         }
         return sum;
 ​
     }
 };
 ​
 //宽度是1  然后给的数组就是代表柱子的高度 所以说看例子就是看他的凹槽可以得到多少水
 ​

很遗憾双指针超时了

复制代码
 class Solution {
 public:
     int trap(vector<int>& height) {
         int ans = 0;
         int left = 0, right = height.size() - 1;
         int leftMax = 0, rightMax = 0;
         while (left < right) {
             leftMax = max(leftMax, height[left]);
             rightMax = max(rightMax, height[right]);
             if (height[left] < height[right]) {
                 ans += leftMax - height[left];
                 ++left;
             } else {
                 ans += rightMax - height[right];
                 --right;
             }
         }
         return ans;
     }
 };
 ​
 ​
相关推荐
小白菜又菜8 分钟前
Leetcode 235. Lowest Common Ancestor of a Binary Search Tree
python·算法·leetcode
We་ct16 分钟前
LeetCode 222. 完全二叉树的节点个数:两种解法详解(BFS + 二分查找优化)
数据结构·算法·leetcode·typescript
小白菜又菜17 分钟前
Leetcode 234. Palindrome Linked List
python·算法·leetcode
阿里云大数据AI技术1 小时前
阿里云PAI助力新一代Qwen3.5模型发布!
人工智能·算法
小白菜又菜1 小时前
Leetcode 221. Maximal Square
算法·leetcode·职场和发展
流云鹤1 小时前
牛客周赛Round 132(无F)
算法
Lee川1 小时前
深入解析:从内存模型到作用域陷阱——JavaScript变量的前世今生
javascript·算法
㓗冽1 小时前
回文数2(字符串)-基础题97th + 加法器(字符串)-基础题98th + 构造序列(字符串)-基础题99th
算法
陈天伟教授2 小时前
人工智能应用- 预测化学反应:02. 化学反应简介
人工智能·神经网络·算法·机器学习·推荐算法
我命由我123452 小时前
Photoshop - Ps还原和历史记录
学习·ui·职场和发展·求职招聘·职场发展·学习方法·photoshop