当前位置: 首页 > article >正文

【力扣打卡系列】单调栈

坚持按题型打卡&刷&梳理力扣算法题系列,语言为go,Day20

单调栈
  • 题目描述
    在这里插入图片描述
  • 解题思路
    • 单调栈
      • 后进先出
        • 记录的数据加在最上面
        • 丢掉数据也先从最上面开始
      • 单调性
        • 记录t[i]之前会先把所有小于等于t[i]的数据丢掉,不可能出现上面大下面小的情况
      • 倒着遍历,while遍历,遇到小的就pop,然后把当前值加进去,栈顶即为最近的大于当前i值对应的数,要存的值就是st[-1]-i
      • 优化的地方:每次拿到元素时就应该和栈顶元素进行比较,直到栈空或者扫描结束
      • 思想:及时去掉无用的数据,保证栈内数据的有序
  • 代码参考
func dailyTemperatures(temperatures []int) []int {
    ans := make([]int,len(temperatures))
    st := []int{}
    for i,j := range slices.Backward(temperatures){
        for len(st) > 0 && j>=temperatures[st[len(st)-1]]{  //注意此处是大于等于
            st = st[:len(st)-1]
        }
        if len(st) > 0{
            ans[i] = st[len(st)-1] - i
        }
        st =append(st,i)
    }
    return ans
}
  • tips
    • 注意倒序遍历的写法:for i,j := range slices.Backward(temperatures)
    • 将ans定义为一个定长切片:ans := make([]int,len(temperatures))
    • st = st[:len(st)-1]
      • st[:len(st)-1] 是对字符串 st 进行切片操作,它取从字符串开始到长度减去1的位置的子字符串。切片操作在 Go 语言中是通过 字符串[开始索引:结束索引] 来实现的。
      • st = st[:len(st)-1] 将切片操作的结果重新赋值给变量 st,这样 st 就更新为去掉了最后一个字符的新字符串

http://www.kler.cn/a/382666.html

相关文章:

  • 基于vue的商城小程序的毕业设计与实现(源码及报告)
  • (概率论)无偏估计
  • iOS - AutoreleasePool
  • 数据库中锁与ETL的故障排除和性能优化
  • Ubuntu中使用miniconda安装R和R包devtools
  • JavaEE初阶——计算机工作原理
  • 熊猫追剧 1.0.0 | 免费追剧软件,全网资源,独家蓝光。
  • 传智杯 第六届-复赛-第二场-C
  • Vue全栈开发旅游网项目(8)-接口联调*2+用户登录
  • AI大模型如何重塑软件开发流程?
  • 工商业储能是什么,工商业储能有什么作用?
  • 作为一个前端开发者 以什么步骤学习后端技术
  • electron 设置最小窗口缩放
  • Java | Leetcode Java题解之第542题01矩阵
  • 高频面试题(含笔试高频算法整理)基本总结回顾32
  • RxJava最全面试题及参考答案
  • Linux qt下是使用搜狗輸入發
  • 全网最适合入门的面向对象编程教程:58 Python字符串与序列化-序列化Web对象的定义与实现
  • Android中Activity启动的模式
  • 算法——双指针
  • macOS15.1及以上系统bug:开发者证书无法打开,钥匙串访问无法打开一直出现图标后立马闪退
  • [项目] C++基于多设计模式下的同步异步日志系统
  • 【青牛科技】GC2803:白色家电与安防领域中 ULN2803 的卓越替代者
  • Laravel/Sail 中修改npm源的问题
  • 京津冀自动驾驶技术行业盛会|2025北京自动驾驶技术展会
  • WPF中如何简单的使用CommunityToolkit.Mvvm创建一个项目并进行 增删改查