美文网首页
栈的最大值问题——深入剖析

栈的最大值问题——深入剖析

作者: wildkid1024 | 来源:发表于2017-09-02 22:56 被阅读0次

常数时间求栈的最大值


问题描述:

一个栈stack,具有push和pop操作,其时间复杂度皆为O(1)。
设计算法max操作,求栈中的最大值,该操作的时间复杂度也要求为O(1)。可以修改栈的存储方式,push,pop的操作,但是要保证O(1)的时间复杂度,空间时间复杂度无要求。

算法描述:
一个存储所有最大值的栈Sm。

  1. 当push入栈的元素大于当前最大元素,将该元素压入最大值栈Sm;
  2. Sm栈顶始终保存栈中当前的最大元素;
  3. 当前最大元素被pop出栈时,将Sm栈顶的对应最大元素也弹出栈。
    max操作即为获得Sm栈顶最大元素。

假设元素以5,4,1,2,3,10,9,8,6,7,15顺序入栈,则两个栈中存储的元素如下图所示:


常数时间空间求栈的最大值


问题描述:
一个整数栈stack,具有push和pop操作,其时间空间复杂度皆为O(1)。
设计算法max操作,求栈中的最大值,该操作的时间空间复杂度也要求为O(1)。可以修改栈的存储方式,push,pop的操作,但是要保证O(1)的时间空间复杂度。

算法描述:
变量Max保存当前最大元素值,初始值为最小整数m。

  1. 当push入栈时,将(当前元素-Max)存入栈中,
    若当前元素小于Max,栈中元素为负数;
    若当前元素大于等于Max,栈中元素为非负数,将Max替换为当前元素。

  2. 当pop出栈时,
    若栈中元素为负数,则将(栈中元素+Max)弹出栈;
    若栈中元素为非负数,则将Max弹出栈,并将Max替换为(Max-栈中元素)。

  3. Max即为当前栈中最大元素值。

主要思路是将最大值以某种方式在原有栈中标记出来,从而减少空间使用。可以用正负数来区分普通元素和最大值元素:
普通元素使用负数存储(元素-Max);
最大值元素使用非负数存储(New Max - Old Max);
这样便可在栈中区分普通元素和最大值元素,并可通过Max恢复Old Max。

假设元素以5,4,1,2,3,10,9,8,6,7,15顺序入栈,则两个栈中存储的元素如下图所示:

  1. 元素5,4,1,2,3入栈后的情况


  2. 元素10,9,8,6,7入栈后的情况


  3. 元素15入栈后的情况


  4. 元素15出栈时的情况


  5. 元素15出栈后的情况(恢复原有状态)


相关文章

  • 栈的最大值问题——深入剖析

    常数时间求栈的最大值 问题描述: 一个栈stack,具有push和pop操作,其时间复杂度皆为O(1)。设计算法m...

  • ijkplayer

    ijkplayer中遇到的问题汇总ijkplayer框架深入剖析

  • 2020-10-10

    深入剖析Linux IO原理和几种零拷贝机制的实现 - 零壹技术栈的文章 - 知乎https://zhuanlan...

  • 函数调用栈

    阅读经典——《深入理解计算机系统》04 函数调用时的栈结构变化是一个很有趣的话题,本文就来详细剖析这个过程。 栈帧...

  • 深入剖析 iOS 性能优化

    深入剖析 iOS 性能优化 深入剖析 iOS 性能优化

  • 线程的基本信息

    空间 主线程栈空间大小为 1M = 1024KB 无法修改(最大值)子线程默认栈控件为 512kb (最大值)并且...

  • JVM的各种参数设置

    -xmx[size]堆的最大值 -xms[size] 堆的最大值 -xss[size]栈的容量 -XX:PermS...

  • 奈学Java架构师训练营 分享vx:itnaer

    大纲 篇章一:《核心基础组件源码深入剖析篇》 第01章:Web 框架深入剖析篇第02章:RPC框架深入剖析篇第03...

  • C语言-3、堆栈、野指针、悬空指针、动态开辟

    栈区:占用内存大小 最大值: 大概 2M 大于2M会栈溢出 跟平台有关系 堆区:占用内存大小 最大值: 大概8...

  • 栈&队列

    一、栈&队列总结 栈/队列的应用接雨水验证栈序列滑动窗口的最大值 栈/队列的特殊实现用两个栈实现队列用两个队列实现...

网友评论

      本文标题:栈的最大值问题——深入剖析

      本文链接:https://www.haomeiwen.com/subject/nmxdjxtx.html