LeetCode -- Implement Stacks using Queue
Question:
Implement the following operations of a queue using stacks.
- push(x) -- Push element x to the back of queue.
- pop() -- Removes the element from in front of queue.
- peek() -- Get the front element.
- empty() -- Return whether the queue is empty.
Notes:
- You must use only standard operations of a stack -- which means only push to top,peek/pop from top,size, andis emptyoperations are valid.
- Depending on your language, stack may not be supported natively. You may simulate a stack by using a list or deque (double-ended queue), as long as you use only standard operations of a stack.
- You may assume that all operations are valid (for example, no pop or peek operations will be called on an empty queue).
Analysis:
问题描述:用队列模仿一个栈。
思路:用两个队列模仿一个栈。每次要pop或者peek时,使用队列倒换一下,剩下最后一个元素单独处理。当且仅当两个队列都为空时,栈才为空。
Answer:
class MyStack {
    Queue<Integer> q1 = new LinkedList<Integer>();
    Queue<Integer> q2 = new LinkedList<Integer>();
    // Push element x onto stack.
    public void push(int x) {
        q1.offer(x);
    }
    // Removes the element on top of the stack.
    public void pop() {
        if(!q1.isEmpty()) {
                while(q1.size() > 1) {
                    int i = q1.poll();
                    q2.offer(i);
                }
                q1.poll();
        } else {
                while(q2.size() > 1) {
                    int i = q2.poll();
                    q1.offer(i);
                }
                q2.poll();
        }
    }
    // Get the top element.
    public int top() {
        if(!q1.isEmpty()) {
            while(q1.size() > 1) {
                int i = q1.poll();
                q2.offer(i);
            }
            int i = q1.poll();
            q2.offer(i);
            return i;
        } else {
            while(q2.size() > 1) {
                int i = q2.poll();
                q1.offer(i);
            }
            int i = q2.poll();
            q1.offer(i);
            return i;
        }
    }
    // Return whether the stack is empty.
    public boolean empty() {
        if(q1.size() == 0 && q2.size() == 0)
                return true;
        return false;
    }
}
LeetCode -- Implement Stacks using Queue的更多相关文章
- [LeetCode] Implement Queue using Stacks 用栈来实现队列
		Implement the following operations of a queue using stacks. push(x) -- Push element x to the back of ... 
- Leetcode Implement Queue using Stacks
		Implement the following operations of a queue using stacks. push(x) -- Push element x to the back of ... 
- LeetCode——Implement Queue using Stacks
		Description: Implement the following operations of a queue using stacks. push(x) -- Push element x t ... 
- LeetCode Implement Queue using Stacks (数据结构)
		题意: 用栈来实现队列. 思路: 一个栈是不够的,至少要两个. (1)插入.永远只插入到stack1中(插到栈顶). (2)弹出.如果stack2不为空,直接弹出stack2的栈顶,否则,将stack ... 
- [LeetCode] Implement Stack using Queues 用队列来实现栈
		Implement the following operations of a stack using queues. push(x) -- Push element x onto stack. po ... 
- [LeetCode] Implement Trie (Prefix Tree) 实现字典树(前缀树)
		Implement a trie with insert, search, and startsWith methods. Note:You may assume that all inputs ar ... 
- [LeetCode] Implement strStr() 实现strStr()函数
		Implement strStr(). Returns the index of the first occurrence of needle in haystack, or -1 if needle ... 
- (leetcode)Implement Stack using Queues
		Implement the following operations of a stack using queues. push(x) -- Push element x onto stack. po ... 
- [Leetcode] implement strStr() (C++)
		Github leetcode 我的解题仓库 https://github.com/interviewcoder/leetcode 题目: Implement strStr(). Returns ... 
随机推荐
- 在Linux文件清空的几种方法
			在Linux文件清空的几种方法 1.使用重定向的方法 [root@centos7 ~]# du -h test.txt 4.0K test.txt [root@centos7 ~]# > tes ... 
- C#后台动态添加Grid表格
			前面页面: <ScrollViewer x:Name=" BorderBrush="#25A0DA" VerticalScrollBarVisibility=&qu ... 
- Linux下使用指定网卡进行ping操作
			目录 1. 为什么要使用知道那个网卡ping操作 2. 使用指定网卡ping操作 3. 总结 1. 为什么要使用指定网卡ping操作 现在很多服务器都拥有双网卡甚至多网卡,有些是为了保持高 ... 
- Linux编译移植Qt4的环境_在OMAPL138平台
			Linux编译Qt4的环境_OMAPL138 手里有一块创龙OMAPL138的板子,我要在上面成功移植Qt环境和触摸屏幕,这是我第二次进行Linux的Qt环境移植,发现了很多问题,需要重新整理. 我编 ... 
- VIM 如何切换buffer
			命令 :ls 可查看当前已打开的buffer 命令 :b num 可切换buffer (num为buffer list中的编号) 其它命令: :bn -- buffer列表中下一个 buffer :b ... 
- 16.2,docker网络
			Docker 允许通过外部访问容器或容器互联的方式来提供网络服务. 端口映射允许外部访问容器 --link 容器互联 容器桥接网络 .通过--link容器通信,给test2添加一个hosts解析记 ... 
- Div处理滚动条问题
			1,用div做容器现在已经十分普遍,下面是最基本的代码 <div style="width:50px;height:50px;background-color:blue"&g ... 
- bootstrap设计进度条和圆点
			1.设计进度条.文字前面的圆点和图片 2.思路: (1)设计进度条 (a) 进度条有滚动效果,要加上类.active (b)进度条的颜色通过类.progress-bar-success来写,可以写成. ... 
- 剑指Offer - 九度1503 - 二叉搜索树与双向链表
			剑指Offer - 九度1503 - 二叉搜索树与双向链表2014-02-05 23:39 题目描述: 输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表.要求不能创建任何新的结点,只能调整树 ... 
- 《Cracking the Coding Interview》——第7章:数学和概率论——题目3
			2014-03-20 02:05 题目:给定笛卡尔二维平面上两条直线,判断它们是否相交. 解法:相交.重合.平行. 代码: // 7.3 Given two lines on the Cartesia ... 
