码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【力扣】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中,js改变字符串中指定字符的颜色 & 在字符串中添加点击事件
    【Rust—LeetCode题解】两数之和
    Kaldi安装(Linux环境)
    试用期生存指南
    Leetcode 116. Populating Next Right Pointers in Each Node (BFS 题)
    MySQL第二讲·表的创建与修改
    螺母加工工艺流程
    【PostgreSQL支持中文的全文检索插件(zhparser)】
    【Spring Boot 使用Filter统一处理请求数据转换】
    Qlik Sense 多表串联详解(Concatenate、NoConcatenate)
  • 原文地址:https://blog.csdn.net/qq_62649563/article/details/133655709
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号