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

对单调栈的理解

这几天一直被单调栈折磨,一直没有理解单调栈的本质,现在相较于之前,我理解了很多。

首先看到下面这张图

这个是一个数列。

然后对这个数列构造一个小压大的单调栈

现在我要求你从原始数列从右向做看,即从 1->2->7->4->5->3

随着下标的移动,找出这个动态后缀的最大值

当下标为6的时候 此时后缀里面的元素 只有1。 后缀最大值为1.

当下标移动到5时,此时后缀里面的元素有 1,2 . 此时后缀最大值为2.

当下标移动到4的时候,此时后缀里面的元素有 1,2,7. 此时后缀最大值为7.

当下标移动到3的时候 ,此时后缀里面的元素有 1,2,7,4. 此时后缀最大值为7.

当下标移动到2的时候,此时后缀里面的元素有 1,2,7,4,5. 此时后缀最大值为7.

当下标移动到1的时候,此时后缀里面的元素有1,2,7,4,5,3. 此时后缀最大值为7.

所以大家发现规律没有?

单调栈从下标和对应的值来看。单调栈一直在动态的“记着”后缀的最大值。它记住了每一个阶段的后缀最大值。由于在栈中存的数列的下标,这个下标可以看成动态“记住”的时间节点。


把“记着”这个动词换成高级一点的词语就是“维护”。 

http://www.xdnf.cn/news/8007.html

相关文章:

  • Spring IOCDI————(2)
  • Linux | tmux | 无法复制粘贴
  • C++类和对象(2)
  • PyTorch学习之:torch.gather是什么?
  • 海康NVR录像回放SDK原始流转FLV视频流:基于Java的流媒体转码(无需安装第三方插件ffmpeg)
  • 远程访问家里的路由器:异地访问内网设备或指定端口网址
  • 芯片分享之X5045PI性能介绍
  • Backbone
  • Typescript 教程
  • Baklib智启企业AI知识管理
  • MySQL 主从复制搭建全流程:基于 Docker 与 Harbor 仓库
  • 杂记10---ldd获取依赖so名称并导出txt文件
  • 数字电子技术基础(六十二)——使用Multisim软件绘制边沿触发的D触发器和JK触发器
  • 2025年 PMP 6月 8月 专题知识
  • Python数据分析基础
  • LangChain入门和应用#1
  • 工商总局可视化模版-Echarts的纯HTML源码
  • CMake跨平台编译生成:从理论到实战
  • 现代计算机图形学Games101入门笔记(二十一)
  • 【Linux安装与维护】
  • 深入理解C#实例构造函数:对象初始化的关键
  • 动态规划3、悟到核心
  • 【DB2】SQL1639N 处理
  • 建立java项目
  • 免费iOS签名的能使用吗?
  • 【钱包协议】:WalletConnect 详解
  • 一步步解析 HTTPS
  • 网络安全管理之钓鱼演练应急预案
  • PCB设计教程【入门篇】——电路分析基础-元件数据手册
  • Nginx核心服务