问题描述:

  如何在O(1)时间复杂度获取栈中的最大值和最小值?

问题分析:

  普通栈规定的push(入栈)、pop(出栈)、peek(查看栈顶)等操作都只能在栈顶上操作,如果栈中元素是有序的,那么我们就可以记录栈顶和栈底元素完成问题要求,但这是不可能的。普通栈不能解决问题,显然我们需要重新定义一种新的栈结构。能否在栈中定义两个变量min和max记录最小值和最大值呢,答案是否定的,因为并不是只有进栈操作,经过一系列出栈操作后,有可能最开始的最大值和最小值已经出栈。为了解决这个问题,我们就需要两个辅助栈记录栈的每个状态下的最大值和最小值。

算法描述:

  定义一个minStack栈和一个maxStack栈,分别在栈顶保存当前栈内最小值和最大值,以minStack为例,每次有元素入栈,就与minStack的栈顶元素比较,若小于栈顶元素,则入栈成为新的栈顶元素,若大于栈顶元素,则入栈原先的栈顶元素,maxStack栈与上述思路相同。出栈时,三个栈都需要出栈。定义getMin与getMax函数分别返回minStack和maxStack栈顶元素,实现在O(1)时间复杂度获取栈中的最小值和最大值。

性能分析:

  时间复杂度:O(1)  

  空间复杂度:O(N)

  加入两个辅助栈实现O(1)时间复杂度获取栈中的最大值和最小值,典型的以空间换取时间。

代码实现:

// Java代码
class MyStack {
public void push(int e) {// 新建MyStack数据结构的push函数
stack.push(e);// 元素入栈
// 判断是否需要更新minStack栈顶元素
if (minStack.isEmpty() || e < minStack.peek()) {
minStack.push(e);// 入栈元素更小,更换栈顶元素
} else if (e >= minStack.peek()) {
minStack.push(minStack.peek());// 不用更换栈顶元素
} // 判断是否需要更新maxStack栈顶元素
if (maxStack.isEmpty() || e > maxStack.peek()) {
maxStack.push(e);// 入栈元素更大,更换栈顶元素
} else if (e <= maxStack.peek()) {
maxStack.push(maxStack.peek());// 不用更换栈顶元素
}
}
public int pop() {// 新建MyStack数据结构的pop函数
// 三栈全部出栈
int ret = stack.pop();
minStack.pop();
maxStack.pop();
return ret;
}
public int getMin() {// O(1)时间返回最小值
return minStack.peek();
}
public int getMax() {// O(1)时间返回最大值
return maxStack.peek();
} private Stack<Integer> stack = new Stack<>();// 存储栈
private Stack<Integer> minStack = new Stack<>();// 最小值辅助栈
private Stack<Integer> maxStack = new Stack<>();// 最大值辅助栈
}
// C++代码
class MyStack {
public:
void push(int e) {// 新建MyStack数据结构的push函数
stacks.push(e);// 元素入栈
// 判断是否需要更新minStack栈顶元素
if (minStack.empty() || e < minStack.top()) {
minStack.push(e);// 入栈元素更小,更换栈顶元素
} else if (e >= minStack.top()) {
minStack.push(minStack.top());// 不用更换栈顶元素
} // 判断是否需要更新maxStack栈顶元素
if (maxStack.empty() || e > maxStack.top()) {
maxStack.push(e);// 入栈元素更大,更换栈顶元素
} else if (e <= maxStack.top()) {
maxStack.push(maxStack.top());// 不用更换栈顶元素
}
}
void pop() {// 新建MyStack数据结构的pop函数
// 三栈全部出栈
stacks.pop();
minStack.pop();
maxStack.pop();
}
int top() {
return stacks.top();
}
int getMin() {// O(1)时间返回最小值
return minStack.top();
}
int getMax() {// O(1)时间返回最大值
return maxStack.top();
} private:
stack<int> stacks;// 存储栈
stack<int> minStack;// 最小值辅助栈
stack<int> maxStack;// 最大值辅助栈
};

如何在O(1)时间复杂度获取栈中最大值和最小值的更多相关文章

  1. js获取数组中最大值和最小值

    var max = Math.max.apply(null, 数组); 获取最大值 var min = Math.min.apply(null, 数组);获取最小值 一句话获取数组中最大的数,最小数

  2. JavaScript 获取数组中最大值、最小值

    笨方法 Array.prototype.max = function() { var max = this[0]; var len = this.length; for (var i = 1; i & ...

  3. js获取数组中最大值,最小值

    遍历方法 var arr =[12,14,34,566,34,98,77] var max = arr[0]; for(var i=0;i<arr.length;i++){ if(max< ...

  4. O(1)时间复杂度求栈中最小元素

    import java.util.Stack; /** * 功能:O(1)时间复杂度求栈中最小元素 * 思路:空间换取时间,使用两个栈,stack1栈存储数据,stack2栈存储最小值: * stac ...

  5. Javascript获取数组中最大和最小值

    取出数组中最大值或最小值是开发中常见的需求,今天继续讲解如何获取javascript数组中最大和最小值. 1.排序法 首先我们给数组进行排序,可以按照从小到大的顺序来排,排序之后的数组中第一个和最后一 ...

  6. JavaScript学习:取数组中最大值和最小值

    在实际业务中有的时候要取出数组中的最大值或最小值.但在数组中并没有提供arr.max()和arr.min()这样的方法.那么是不是可以通过别的方式实现类似这样的方法呢?那么今天我们就来整理取出数组中最 ...

  7. java基础编程——获取栈中的最小元素

    题目描述 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1)).   题目代码 /** * Created by YuKai Fan on 2018/9 ...

  8. 转载——JavaScript学习笔记:取数组中最大值和最小值

    转载自:http://www.w3cplus.com/javascript/calculate-the-max-min-value-from-an-array.html. 取数组中最大值 可以先把思路 ...

  9. JavaScript 获取数组的最大值和最小值

    js获取数组最大值和最小值 使用apply方法: var a = [1,2,3,5]; console.log(Math.max.apply(null, a));//最大值 console.log(M ...

随机推荐

  1. Dart & data type(static / dynamic)

    Dart & data type(static / dynamic) Darts 飞镖 标枪 javelin/darts type https://dartpad.dartlang.org/ ...

  2. trao 模拟点击 & js auto click

    trao 模拟点击 & js auto click 日历上选择某一天,在 scrollview 自动定位到选择的那一天 click 后获取 item 的 e.target.offsetLeft ...

  3. nasm astrncat_s函数 x86

    xxx.asm: %define p1 ebp+8 %define p2 ebp+12 %define p3 ebp+16 %define p4 ebp+20 section .text global ...

  4. Flutter: moor_flutter库,简化sqlite操作

    入门 video moor_flutter 示例代码仓库 install dependencies: ... moor_flutter: dev_dependencies: ... moor_gene ...

  5. NGK的去中心化自治实践,更人性化的DAO

    2020年,DeFi市场市场火爆的同时,引爆了流动性挖矿的市场.行业内对DAO的思考也在源源不断进行,特别项目治理通证发行之前,DAO的去中心化的治理理念,是区块链属性中的重要的一环,也已引发了不同项 ...

  6. spring boot用ModelAndView向Thymeleaf模板传参数

    最近在调试一个Spring Boot向Thymeleaf模板传参数的例子,但踩了很多坑,这里就把详细过程记录下来,以供大家参考. 先说下,这里遇到哪些坑呢? 1 我用的是IDEA社区版,这不支持JSP ...

  7. 开源OA办公平台搭建教程:O2OA+Arduino实现物联网应用(二)

    O2OA平台搭建 O2OA的开发环境非常简单,安装服务器后即可通过浏览器进行开发了和使用.具体可参考文档库中的其他文档,有比较详细的介绍,这里就不再赘述了. Arduino开发发环境搭建 安装Ardu ...

  8. SpringBoot源码解析

    1.@SpringBootApplication springboot采用注解方式开发的,当创建了一个springboot项目时,在启动类上会有一个注解@SpringBootApplication,这 ...

  9. SpringBoot(三):SpringBoot热部署插件

    SpringBoot热部署插件 在实际开发中,我们修改了某些代码逻辑功能或页面都需要重启应用,这无形中降低了开发效率!热部署是指当我们修改代码后,服务能自动启动加载新修改的内容,这样大大提高了我们开发 ...

  10. R语言低级绘图函数画个温度计

    x <- 1:2 y <- runif(2,0,100) par(mar=c(4,6,2,6)) plot(x,y,type="n",xlim=c(0.5,2.5),y ...