力扣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;
      }
  };
相关推荐
YGGP6 分钟前
【Golang】LeetCode 1351. 统计有序矩阵中的负数
leetcode·矩阵
漫随流水8 分钟前
leetcode算法(20.有效的括号)
数据结构·算法·leetcode
如果你想拥有什么先让自己配得上拥有10 分钟前
数、自然数、整数、有理数、无理数它们的定义由来和边界划分
算法
Xの哲學1 小时前
Linux SLUB 内存分配器深度剖析: 从设计哲学到实战调试
linux·服务器·网络·算法·边缘计算
2401_876221341 小时前
AtCoder Beginner Contest 439 - D - Kadomatsu Subsequence
c++·算法
小丁努力不焦虑2 小时前
算法期末总结题
数据结构·算法
嵌入式进阶行者2 小时前
【算法】从数组中选取两个符合一定条件的数的算法与实例:华为OD机考双机位A卷 - 跳房子I
数据结构·c++·算法·链表
老歌老听老掉牙2 小时前
从战场到商场:最优化算法如何用数学重塑世界?
python·算法·最优化
im_AMBER2 小时前
Leetcode 94 合并零之间的节点
数据结构·c++·笔记·学习·算法·leetcode
KingRumn2 小时前
DBUS源码剖析之DBusMessage消息头
linux·服务器·算法