测试步骤
push(1)
push(2)
push(3)
pop()
pop()
push(4)
push(5)
pop()
pop()
pop()
思路
前三次push()
data:image/s3,"s3://crabby-images/4c216/4c2164e549140ccc01b2b0a3f8e606708dd655d8" alt=""
两次pop()
我们可以使用以下方法把s1的内容移到s2,翻转一下,此时stack2.pop()的值就是队首
while(!stack1.empty()){
stack2.push(stack1.pop();
}
data:image/s3,"s3://crabby-images/2259c/2259c403b4eabfdbd64748785284a7fd8330694b" alt=""
data:image/s3,"s3://crabby-images/b9130/b91305d20cd1444e1aa2a79357b4956d8c1af6fc" alt=""
两次push()
把要push的值都往stack1里面放,此时你会发现,如果我们要pop队列,只需pop栈2就好了
data:image/s3,"s3://crabby-images/61567/615678cfab92c9d5c6c826c89792b8fc70a85298" alt=""
三次pop()
第一次pop()掉stack2的内容,当stack2为空时,我们又回到最初的选择,把stack1的元素全部翻转到stack2,然后popStack2
data:image/s3,"s3://crabby-images/52798/5279847954f895627b6b3e26f30c8027b6952579" alt=""
data:image/s3,"s3://crabby-images/a353d/a353d1f48936d142dacf83bd97a63f4fa9c2eb3b" alt=""
data:image/s3,"s3://crabby-images/e05d9/e05d942e01ad6183a5048e47206231a13fdece76" alt=""
data:image/s3,"s3://crabby-images/7801a/7801adc133d091edb56fd857da95e8b399a96c70" alt=""
Java代码
import java.util.Stack;
public class Solution {
Stack<Integer> stack1 = new Stack<Integer>();
Stack<Integer> stack2 = new Stack<Integer>();
public void push(int node) {
stack1.push(node);
}
public int pop() {
//栈2非空
if(!stack2.empty()){
return stack2.pop();
}
//栈2为空
if(stack1.size()==1){
return stack1.pop();
}
else{
while(!stack1.empty()){
stack2.push(stack1.pop());
}
return stack2.pop();
}
}
}
网友评论