Java实现栈和队列面试题实现栈和队列面试题
主要介绍了Java实现栈和队列的面试题,每个例题代码实现非常详细,每一个方法讲解也很到位,特别适合参加Java面试的朋友
阅读。
面试的时候,栈和队列经常会成对出现来考察。本文包含栈和队列的如下考试内容:
((1)栈的创建)栈的创建
((2)队列的创建)队列的创建
((3)两个栈实现一个队列)两个栈实现一个队列
((4)两个队列实现一个栈)两个队列实现一个栈
((5)设计含最小函数)设计含最小函数min()的栈,要求的栈,要求min、、push、、pop、的时间复杂度都是、的时间复杂度都是O(1)
((6)判断栈的)判断栈的push和和pop序列是否一致序列是否一致
1、栈的创建:、栈的创建:
我们接下来通过链表的形式来创建栈,方便扩充。
代码实现:
public class Stack {
public Node head;
public Node current;
//方法:入栈操作
public void push(int data) {
if (head == null) {
head = new Node(data);
current = head;
} else {
Node node = new Node(data);
node.pre = current;//current结点将作为当前结点的前驱结点
current = node; //让current结点永远指向新添加的那个结点
}
}
public Node pop() {
if (current == null) {
return null;
}
Node node = current; // current结点是我们要出栈的结点
current = current.pre; //每出栈一个结点后,current后退一位
return node;
}
class Node {
int data;
Node pre; //我们需要知道当前结点的前一个结点
public Node(int data) {
this.data = data;
}
}
public static void main(String[] args) {
Stack stack = new Stack();
stack.push(1);
stack.push(2);
stack.push(3);
System.out.println(stack.pop().data);
System.out.println(stack.pop().data);
System.out.println(stack.pop().data);
}
}
入栈操作时,14、15行代码是关键。
运行效果: