• 【力扣】42. 接雨水


    这道题我卡了差不多1个小时,不是不会做,是不知道怎么能用栈来实现,后面看了一个博主的视频,豁然开朗,我主要的纠结点在于当指针指到7的时候,我计算出4到7的水块是2,但实际上是0,因为用栈是横向求解的,就是你横着来切一刀就行,然后掌握其原理。

    先放代码吧,看不懂再看我的题解

    1. class Solution {
    2. public int trap(int[] height) {
    3. //定义水块和
    4. int sum=0;
    5. Stack stack=new Stack<>();
    6. int current=0;
    7. while(current
    8. while(!stack.empty()&&height[current]>height[stack.peek()]){
    9. //获得栈顶元素的高度
    10. int h=height[stack.peek()];
    11. stack.pop(); //出栈
    12. if(stack.empty()){
    13. break;
    14. }
    15. //计算方式
    16. int dt=current-stack.peek()-1;
    17. int min=Math.min(height[current],height[stack.peek()]);
    18. sum=sum+(min-h)*dt;
    19. }
    20. //存放的是坐标
    21. stack.push(current);
    22. current+=1;
    23. }
    24. return sum;
    25. }
    26. }

    题解如下:

    1.首先讲一下原理,栈,用的时候注意里面存放的是单调递增的元素,从下往上看

    2.过程:

    根据本题来看,首先第一个height[0]入栈,指针后移,此时指针所指向的元素大于栈顶元素,所以栈顶元素出栈。height[1]入栈,指针后移,此时指针所指向的元素小于栈顶元素,height[2]入栈指针后移,height[3]>height[2],所以height[2]出栈 ,找到height[2]左边的比他大的元素,也就是栈顶元素。这个其实是已经排序好的,懂吧,然后比较左边和右边的元素,找出最小值,再减去之前出栈的元素的高度,再乘以左右两边元素之差-1,就是这样子,这个计算方法就是这样的,后面也就以此类推了。再见!祝各位刷题人happy !

  • 相关阅读:
    Vue页面路由参数的传递和获取
    麒麟系统开机忘记密码,密码重置
    令人困惑的 Go time.AddDate
    【LeetCode75】第五十五题 寻找峰值
    http日志打印
    矩阵乘法和组合计数
    Django 创建项目时找不到数据库sqlite3
    OpenCV 14(角点特征Harris和Shi-Tomasi)
    SpringCloudalibaba2
    【Java SE】封装,面向对象三大特性之一
  • 原文地址:https://blog.csdn.net/qq_62649563/article/details/133655709