LeetCode 刷题【42. 接雨水】

42. 接雨水

自己做

解:双指针左右分割容器

cpp 复制代码
class Solution {
public:
    int trap(vector<int>& height) {
        int res = 0;
        int len = height.size();
        
        if(len <= 2)      //构不成一个容器了,直接返回
          return res;

        int end = len - 1;        //右边界
        int start = 0;            //左边界

        //对左边的边界初始化
        while(height[start] <= height[start + 1]){    //排除前面部分
          start++;

          if(start == end - 1)      //构不成一个容器了,直接返回
            return res;
        }

        //对右边的边界初始化
        while(height[end - 1] >= height[end]){    //排除后面部分
          end--;

          if(end == start + 1)      //构不成一个容器了,直接返回
            return res;
        }

        int left = start + 1;     //左边容器起始
        int right = end - 1;      //右边容器起始



        //从左往右靠拢
        int left_capacity = 0;
        while(left <= end){
          if(height[left] < height[start]){ //当遇到比边界小的时,将其看做底,计算当前容器的容量
            left_capacity += height[start] - height[left];    //累加当前容器的容量
          }
          else{                           //当遇到比边界大或者相等时,该容器就封边了,开始找下个容器
            start = left;                 //新的容器边界
            res += left_capacity;          //将该容器的容量累加进结果中
            left_capacity = 0;            //重置容量
          }
          
          left++;                         //延伸容器
        }

         //从右往左靠拢
        int right_capacity = 0;
        while(right >= start){
          if(height[right] < height[end]){ //当遇到比边界小的时,将其看做底,计算当前容器的容量
            right_capacity += height[end] - height[right];    //累加当前容器的容量
          }
          else{                           //当遇到比边界大或者相等时,该容器就封边了,开始找下个容器
            end = right;                 //新的容器边界
            res += right_capacity;          //将该容器的容量累加进结果中
            right_capacity = 0;            //重置容量
          }
          
          right--;                         //延伸容器
        }
  
      return res;

    }
};

今日总结

好耶,写的第一版代码直接没有任何报错地过了,也是能跑到最优解的程度,今天没有任何调试,一遍过

相关推荐
iCxhust4 分钟前
在 emu8086 中可以直接编译运行的完整汇编程序,演示数组的定义、遍历、求和、求最大值。
开发语言·前端·javascript·汇编·单片机·嵌入式硬件·算法
Jinkxs12 分钟前
LoadBalancer- 常见负载均衡算法:轮询 / 加权轮询 / 最少连接等基础实现
运维·算法·负载均衡
Brilliantwxx24 分钟前
【C++】认识vector(概念+题目OJ)
开发语言·c++·笔记·算法
逻辑驱动的ken27 分钟前
Java高频面试考点场景题22
java·开发语言·jvm·面试·职场和发展·求职招聘·春招
m0_6294947328 分钟前
LeetCode 热题 100-----18.矩阵置零
数据结构·leetcode·矩阵
生成论实验室1 小时前
《事件关系阴阳博弈动力学:识势应势之道》第十篇:识势应势——从认知到行动的完整闭环
人工智能·算法·架构·创业创新·安全架构
risc1234561 小时前
SegmentTermsEnum#postings 和 IntersectTermsEnum#postings
算法·lucene
阿Y加油吧1 小时前
二刷 LeetCode:两道经典贪心题复盘
算法·leetcode·职场和发展
顺顺 尼1 小时前
程序地址空间和进程的一些操作
算法
Java成神之路-1 小时前
【LeetCode 刷题笔记】35. 搜索插入位置 | 二分查找经典入门题
算法·leetcode