题目:
定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1))。
代码实现:
import java.util.Stack;
import java.util.Iterator;
public class Solution {
//定义一个栈
Stack<Integer> stack=new Stack<>();
public void push(int node) {
//调用入栈函数
stack.push(node);
}
public void pop() {
//调用出栈函数
stack.pop();
}
public int top() {
//取得栈顶元素
return stack.peek();
}
public int min() {
//默认栈顶元素为最小值
int min=stack.peek();
int temp=0;
//用迭代器来遍历栈里元素
Iterator<Integer> iterator=stack.iterator();
while(iterator.hasNext())
{
temp=iterator.next();
if(min>temp)
{
min=temp;
}
}
return min;
}
}