0
点赞
收藏
分享

微信扫一扫

怎样用队列实现栈?怎样用栈实现队列?

一、栈

栈:先进后出。

方法功能
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();
}

}
举报

相关推荐

0 条评论