力扣1670.设计前中后队列

力扣1670.设计前中后队列

  • 两个双端队列

    • 始终保证right.size() >= left.size()
    • 向中间插入时如果一样长 就插入right
    • 如果right长就插入left
cpp 复制代码
  class FrontMiddleBackQueue {
  private:
      deque<int> left;
      deque<int> right;
      //保证left.size() + 1 >= right.size() >= left.size()
      void banlance()
      {
          if(left.size() > right.size())
          {
              right.push_front(left.back());
              left.pop_back();
          }
          else if(right.size() > left.size() + 1)
          {
              left.push_back(right.front());
              right.pop_front();
          }
      }
  public:
      
      FrontMiddleBackQueue() {
  
      }
      
      void pushFront(int val) {
          left.push_front(val);
          banlance();
      }
      
      void pushMiddle(int val) {
          if(left.size() < right.size())
              left.push_back(val);
          else
              right.push_front(val);
      }
      
      void pushBack(int val) {
          right.push_back(val);
          banlance();
      }
      
      int popFront() {
          if(right.empty())
              return -1;
          int val;
          if(left.empty())
          {
              val = right.front();
              right.pop_front();
          }
          else
          {
              val = left.front();
              left.pop_front();
          }
          banlance();
          return val;
      }
      
      int popMiddle() {
          if(right.empty())
              return -1;
          int val;
          if(left.size() == right.size())
          {
              val = left.back();
              left.pop_back();
          }
          else
          {
              val = right.front();
              right.pop_front();
          }
          return val;
      }
      
      int popBack() {
          if(right.empty())
              return -1;
          int val = right.back();
          right.pop_back();
          banlance();
          return val;
      }
  };
相关推荐
源代码•宸10 小时前
Golang原理剖析(逃逸分析)
经验分享·后端·算法·面试·golang··内存逃逸
重生之后端学习10 小时前
25. K 个一组翻转链表
java·数据结构·算法·leetcode·职场和发展
CoderCodingNo10 小时前
【GESP】C++五级练习题 luogu-P2242 公路维修问题
开发语言·c++·算法
不知名XL10 小时前
day30 动态规划03
算法·动态规划
张祥64228890410 小时前
线性代数本质笔记十二
人工智能·算法·机器学习
程序员-King.10 小时前
day157—回溯—括号生成(LeetCode-22)
算法·leetcode·回溯
Σίσυφος190010 小时前
视觉矩阵 之 单应矩阵
人工智能·算法·矩阵
啊阿狸不会拉杆11 小时前
《机器学习》第五章-集成学习(Bagging/Boosting)
人工智能·算法·机器学习·计算机视觉·集成学习·boosting
信奥卷王11 小时前
2025年3月GESPC++四级真题解析(含视频)
算法
后来后来啊11 小时前
2026.1.21学习笔记
笔记·学习·leetcode·#算法·#cpp