zoukankan      html  css  js  c++  java
  • 225. Implement Stack using Queues

    Implement the following operations of a stack using queues.

    • push(x) -- Push element x onto stack.
    • pop() -- Removes the element on top of the stack.
    • top() -- Get the top element.
    • empty() -- Return whether the stack is empty.

    Notes:

      • You must use only standard operations of a queue -- which means only push to backpeek/pop from frontsize, and is empty operations are valid.
      • Depending on your language, queue may not be supported natively. You may simulate a queue by using a list or deque (double-ended queue), as long as you use only standard operations of a queue.
      • You may assume that all operations are valid (for example, no pop or top operations will be called on an empty stack).

    题目含义:使用queue来实现stack的功能

     1 class MyStack {
     2 
     3     private Queue<Integer> p = new LinkedList<>();
     4 
     5     /** Initialize your data structure here. */
     6     public MyStack() {
     7 
     8     }
     9 
    10     /** Push element x onto stack. */
    11     public void push(int x) {
    12         p.add(x);
    13         for (int i=1;i<p.size();i++)
    14         {
    15             p.add(p.poll());
    16         }
    17     }
    18 
    19     /** Removes the element on top of the stack and returns that element. */
    20     public int pop() {
    21         return p.poll();
    22     }
    23 
    24     /** Get the top element. */
    25     public int top() {
    26         return p.peek();
    27     }
    28 
    29     /** Returns whether the stack is empty. */
    30     public boolean empty() {
    31         return p.isEmpty();
    32     }
    33 }
  • 相关阅读:
    C# 高效字符串连接 StringBuilder介绍
    C#图解教程
    C#中string类型是值类型还是引用类型?
    UML类图10分钟快速入门
    C#设计模式--单例模式
    计算机是如何启动的?
    2018年计划
    转:SQL进阶之变量、事务、存储过程与触发器
    2020/02/06,武汉
    2020/02/06,渐渐,from eason for you for her
  • 原文地址:https://www.cnblogs.com/wzj4858/p/7725653.html
Copyright © 2011-2022 走看看