c++重拾STL之 队列:queue、deque

queue

头文件#include
queue模板类两个模板参数:一个是元素类型,一个是容器类型,容器类型默认为deque类型。

1、定义queue对象:

queue q1;
queue q2

2、queue的基本操作

  • 入队: q.push(x); 入到队尾
  • 出队:q.pop(); 弹出队列第一个元素,**注意,pop出队只是删除队头元素,并不会返回被弹出的元素!!!和stack的pop一样**
  • 访问队首元素:q.front(); 即最早被压入队列的元素
  • 访问队尾元素:q.back(); 即最后被亚茹队列的元素
  • 判断队空:q.empty(); 当队列空时,返回true
  • 队中元素个数:q.size();

双向队列deque

头文件#include
两端的每一端都既可以删除也可以添加元素 / 头尾两端都可以增删元素。
(queue要是在A端添加的话,就只能在B端删)

deque和vector一样,都是采用动态数组来管理元素。
deque两端都能够快速插入和删除元素。vector只能一头。

1、定义deque对象

deque dq

2、deque的基本操作

  • dq.front(): 访问第一个元素
  • dq.back():访问最后一个元素
  • dq.push_front(x): 从队头入队/ 添加元素到队头
  • dq.push_back(x): 从队尾入队/ 添加元素到队尾
  • dq.pop_front(): 从队头出队/ 删除队头的元素
  • dq.pop_back(): 从队尾出队/ 删除队尾的元素
  • dq.empty()
  • dq.size()

使用示例:

二叉树层次遍历:
一般直接用deque。deque的功能比queue更全。

class Solution {
    //层次遍历: 用队列
public:
    vector<int> PrintFromTopToBottom(TreeNode* root) {
       
        
        vector<int> res;//问题要求要用vector返回
         if(root==nullptr)    return res;
        
        deque<TreeNode*> dq;
        dq.push_front(root);//先把头添加到队里
        while(!dq.empty()){
            //访问队头/打印队头(输出结果)
            TreeNode* pNode= dq.front();
            res.push_back(pNode->val);
            //队头出去
            dq.pop_front();
            
            //孩子进来
            if(pNode->left)
                dq.push_back(pNode->left);
            if(pNode->right)
                dq.push_back(pNode->right);
        }
        return res;
    }
};

你可能感兴趣的:(c++)