如何在O(1)时间复杂度获取栈中最大值和最小值
问题描述:
如何在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)时间复杂度获取栈中最大值和最小值的更多相关文章
- js获取数组中最大值和最小值
var max = Math.max.apply(null, 数组); 获取最大值 var min = Math.min.apply(null, 数组);获取最小值 一句话获取数组中最大的数,最小数
- JavaScript 获取数组中最大值、最小值
笨方法 Array.prototype.max = function() { var max = this[0]; var len = this.length; for (var i = 1; i & ...
- js获取数组中最大值,最小值
遍历方法 var arr =[12,14,34,566,34,98,77] var max = arr[0]; for(var i=0;i<arr.length;i++){ if(max< ...
- O(1)时间复杂度求栈中最小元素
import java.util.Stack; /** * 功能:O(1)时间复杂度求栈中最小元素 * 思路:空间换取时间,使用两个栈,stack1栈存储数据,stack2栈存储最小值: * stac ...
- Javascript获取数组中最大和最小值
取出数组中最大值或最小值是开发中常见的需求,今天继续讲解如何获取javascript数组中最大和最小值. 1.排序法 首先我们给数组进行排序,可以按照从小到大的顺序来排,排序之后的数组中第一个和最后一 ...
- JavaScript学习:取数组中最大值和最小值
在实际业务中有的时候要取出数组中的最大值或最小值.但在数组中并没有提供arr.max()和arr.min()这样的方法.那么是不是可以通过别的方式实现类似这样的方法呢?那么今天我们就来整理取出数组中最 ...
- java基础编程——获取栈中的最小元素
题目描述 定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1)). 题目代码 /** * Created by YuKai Fan on 2018/9 ...
- 转载——JavaScript学习笔记:取数组中最大值和最小值
转载自:http://www.w3cplus.com/javascript/calculate-the-max-min-value-from-an-array.html. 取数组中最大值 可以先把思路 ...
- JavaScript 获取数组的最大值和最小值
js获取数组最大值和最小值 使用apply方法: var a = [1,2,3,5]; console.log(Math.max.apply(null, a));//最大值 console.log(M ...
随机推荐
- 一个模块如何同时支持 ESM 和 CJS
一个模块如何同时支持 ESM 和 CJS 模块转化 webpack + babel refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问 ...
- js debounce & throttle All In One
js debounce & throttle All In One debounce & throttle js 节流 防抖 debounce 防抖 防抖,是指一个事件触发后在单位时间 ...
- cnblogs 日期错乱 bug
cnblogs 日期错乱 bug 时间错乱 bug archive/2004/01/13/ 什么鬼 呀默认时间戳 https://www.cnblogs.com/xgqfrms/archive/200 ...
- yarn global add !== yarn add global
yarn global add !== yarn add global yarn does not exist the --global flag, but exits yarn global com ...
- how to auto open a url in the browser by using terminal
how to auto open a url in the browser by using terminal Linux / MacOS # bash / zsh $ open http://loc ...
- YAML & .yml
YAML & .yml YAML: YAML Ain't Markup Language https://yaml.org/ https://github.com/yaml/www.yaml. ...
- css & circle & shapes
css & circle & shapes css-tricks circle https://css-tricks.com/the-shapes-of-css/ https://cs ...
- React & Dva & Actions & dispatch & effects
React & Dva & Actions & dispatch & effects dispatch https://dvajs.com/guide/introduc ...
- Build your own React
Build your own React https://pomb.us/build-your-own-react/ https://github.com/pomber/didact demo htt ...
- JULLIAN MURPHY:拥有良好的心态,运气福气便会自来
JULLIAN MURPHY是星盟全球投资公司的基金预审经理,负责星盟投资项目预审,有着资深的基金管理经验,并且在区块链应用的兴起中投资了多个应用区块链技术的公司. JULLIAN MURPHY认为往 ...