C++解LeetCode232. 用栈实现队列(适合基础薄弱)

举报
莫浅子 发表于 2022/12/21 22:08:34 2022/12/21
【摘要】 ​请你仅使用两个栈实现先入先出队列。队列应当支持一般队列支持的所有操作(push、pop、peek、empty):实现 MyQueue 类:void push(int x) 将元素 x 推到队列的末尾int pop() 从队列的开头移除并返回元素int peek() 返回队列开头的元素boolean empty() 如果队列为空,返回 true ;否则,返回 false说明:你 只能 使用标...


请你仅使用两个栈实现先入先出队列。队列应当支持一般队列支持的所有操作(push、pop、peek、empty):


实现 MyQueue 类:

void push(int x) 将元素 x 推到队列的末尾
int pop() 从队列的开头移除并返回元素
int peek() 返回队列开头的元素
boolean empty() 如果队列为空,返回 true ;否则,返回 false


说明:

你 只能 使用标准的栈操作 —— 也就是只有 push to top, peek/pop from top, size, 和 is empty 操作是合法的。
你所使用的语言也许不支持栈。你可以使用 list 或者 deque(双端队列)来模拟一个栈,只要是标准的栈操作即可。
 

示例 1:

输入:
["MyQueue", "push", "push", "peek", "pop", "empty"]
[[], [1], [2], [], [], []]
输出:
[null, null, null, 1, 1, false]


解释:
MyQueue myQueue = new MyQueue();
myQueue.push(1); // queue is: [1]
myQueue.push(2); // queue is: [1, 2] (leftmost is front of the queue)
myQueue.peek(); // return 1
myQueue.pop(); // return 1, queue is [2]
myQueue.empty(); // return false

步骤

1、如果直接将要插入的元素放进去,那么这个元素就是top,可是按队列的插入方式这个元素应该是尾部,所以不能直接插入

编辑

2、先创造一个临时的栈,把一二三四依次放进去

编辑

3、在把要插入的元素5放进这个临时的栈

 编辑


4、最后把临时的栈元素放进原数据栈

编辑



class MyQueue {
public:
    stack<int> date_stack;          //原数据栈
    stack<int> temp_stack;          //临时栈
    MyQueue() {

    }
    
    void push(int x) {
        while(!date_stack.empty()){
        temp_stack.push(date_stack.top());       //把原数据栈的元素依次放进去
        date_stack.pop();                        //把原数据栈依次弹出
        }
        temp_stack.push(x);                     
        while(!temp_stack.empty()){
            date_stack.push(temp_stack.top());
            temp_stack.pop();
        }       
    }
    
    int pop() {
      int x = date_stack.top();
      date_stack.pop();
      return x;
    }
    
    int peek() {
        return date_stack.top();
    }
    
    bool empty() {
         return date_stack.empty();
    }
};

类似的题目有

用队列实现栈C++解LeetCode225. 用队列实现栈(适合基础薄弱

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。