您的位置:首页 > 职场人生

剑指Offer:面试题21——包含min函数的栈(java实现)

2016-07-07 10:58 393 查看
问题描述:

定义栈的数据结构,请在该类型中实现一个能够得到栈的最小元素的min函数。在该栈中,调用min,push及pop的时间复杂度都是O(1).

思路:加入一个辅助栈用来存储最小值集合

(这里要注意题目并没有说栈内的元素类型,因此要尽量通用)

import java.util.Stack;

public class Solution {

Stack s1=new Stack();
Stack min=new Stack();
public void push(int node) {
if(min.empty()){
min.push(node);
}else{
int top=(int)min.peek();
if(node<top){
min.push(node);
}else{
min.push(top);
}
}
s1.push(node);
}

public void pop() {
if(!(s1.empty())){
s1.pop();
min.pop();
}
}

public int top() {
return (int)s1.peek();
}

public int min() {
if(min.empty()){
return 0;
}
return (int)min.peek();
}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java 面试题