Problem: 225. 用队列实现栈
文章目录
- 思路
- 复杂度
- Code
思路
👨🏫 力扣官解
 
- 辅助队列存栈顶元素
- 主队列存逆序序列
复杂度
时间复杂度:
添加时间复杂度, 示例: O ( n ) O(n) O(n)
空间复杂度:
添加空间复杂度, 示例: O ( n ) O(n) O(n)
Code
class MyStack {
    Queue<Integer> q1;
    Queue<Integer> q2;
    public MyStack() {
        q1 = new LinkedList<Integer>();
        q2 = new LinkedList<Integer>();
    }
    
    public void push(int x) {
        q2.add(x);
        while(!q1.isEmpty())
        {
            q2.add(q1.poll());
        }
         Queue<Integer> tmp = q1;
         q1 = q2;
         q2 = tmp;
    }
    
    public int pop() {
        return q1.poll();
    }
    
    public int top() {
        return q1.peek();
    }
    
    public boolean empty() {
        return q1.size() == 0;
    }
}
/**
 * Your MyStack object will be instantiated and called as such:
 * MyStack obj = new MyStack();
 * obj.push(x);
 * int param_2 = obj.pop();
 * int param_3 = obj.top();
 * boolean param_4 = obj.empty();
 */





![BUUCTF---[BJDCTF2020]藏藏藏1](https://img-blog.csdnimg.cn/direct/65af539ad7ab427f885b2aa3e1f3936a.png)



![[LeetBook]【学习日记】寻找链表相交节点](https://img-blog.csdnimg.cn/direct/0bb42fc0ba544f04b871c53b26d084d2.png)










