一、栈
栈:先进后出。
方法 | 功能 |
---|---|
Stack() | 构造一个空的栈 |
E push(E e) | 将e入栈,并返回e |
E pop() | 将栈顶元素出栈并返回 |
E peek() | 获取栈顶元素 |
int size() | 获取栈中有效元素个数 |
boolean empty() | 检测栈是否为空 |
二、队列
队列:先进先出。
方法 | 功能 |
---|---|
boolean offer(E e) | 入队列 |
E poll() | 出队列 |
peek() | 获取队头元素 |
int size() | 获取队列中有效元素个数 |
boolean isEmpty() | 检测队列是否为空 |
三、用队列实现栈
- 解题思路
- 代码
import java.util.*;
class MyStack {
public Queue<Integer> qu1;
public Queue<Integer> qu2;
public MyStack() {
this.qu1=new LinkedList<>();
this.qu2=new LinkedList<>();
}
//将元素 x 压入栈顶
public void push(int x) {
if(!qu1.isEmpty()){
qu1.offer(x);
}else if(!qu2.isEmpty()){
qu2.offer(x);
}else{//都为空时
qu1.offer(x);
}
}
//移除并返回栈顶元素
public int pop() {
if(empty()){
return -1;
}
if(!qu1.isEmpty()){
int size=qu1.size();//循环中size一直在改变,需提前定义
for(int i=0;i<size-1;i++){
int x=qu1.poll();
qu2.offer(x);
}
return qu1.poll();
}else{
int size=qu2.size();//循环中size一直在改变,需提前定义
for(int i=0;i<size-1;i++){
int x=qu2.poll();
qu1.offer(x);
}
return qu2.poll();
}
}
//返回栈顶元素
public int top() {
if(empty()){
return -1;
}
if(!qu1.isEmpty()){
int x=-1;
int size=qu1.size();//循环中size一直在改变,需提前定义
for(int i=0;i<size;i++){
x=qu1.poll();
qu2.offer(x);
}
return x;
}else{
int x=-1;
int size=qu2.size();//循环中size一直在改变,需提前定义
for(int i=0;i<size;i++) {
x=qu2.poll();
qu1.offer(x);
}
return x;
}
}
//如果栈是空的,返回 true ;否则,返回 false
public boolean empty() {
return qu1.isEmpty()&&qu2.isEmpty();
}
}
四、用栈实现队列
- 解题思路
- 代码
import java.util.*;
class MyQueue {
public Stack<Integer> st1;
public Stack<Integer> st2;
public MyQueue() {
this.st1=new Stack<>();
this.st2=new Stack<>();
}
//将元素 x 推到队列的末尾
public void push(int x) {
st1.push(x);
}
//从队列的开头移除并返回元素
public int pop() {
if(empty()){
return -1;
}
if(st2.empty()){
while(!st1.empty()){
int x=st1.pop();
st2.push(x);
}
}
return st2.pop();
}
//返回队列开头的元素
public int peek() {
if(empty()){
return -1;
}
if(st2.empty()){
while(!st1.empty()){
int x=st1.pop();
st2.push(x);
}
}
return st2.peek();
}
//如果队列为空,返回 true ;否则,返回 false
public boolean empty() {
return st1.empty()&& st2.empty();
}
}