力扣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;
      }
  };
相关推荐
無限進步D11 分钟前
Java 基础算法训练
java·开发语言·算法·入门
圣保罗的大教堂18 分钟前
leetcode 2087. 网格图中机器人回家的最小代价 中等
leetcode
门左有棵树19 分钟前
蓝桥杯C++组算法知识点整理(考前急救)
c++·算法·蓝桥杯
历程里程碑31 分钟前
二叉树---二叉树的最大深度
大数据·数据结构·算法·elasticsearch·搜索引擎·全文检索·深度优先
自我意识的多元宇宙33 分钟前
树与二叉树--树的基本概念
数据结构·算法
吃着火锅x唱着歌34 分钟前
LeetCode 678.有效的括号字符串
算法·leetcode·职场和发展
音视频牛哥2 小时前
鸿蒙 NEXT RTSP/RTMP 播放器如何回调 RGB 数据并实现 AI 视觉算法分析
人工智能·算法·harmonyos·鸿蒙rtmp播放器·鸿蒙rtsp播放器·鸿蒙next rtsp播放器·鸿蒙next rtmp播放器
飞Link2 小时前
掌控 Agent 的时空法则:LangGraph Checkpoint (检查点) 机制深度实战
开发语言·python·算法
乐迪信息2 小时前
智慧港口中AI防爆摄像机的船舶越线识别功能
大数据·人工智能·物联网·算法·目标跟踪
F_D_Z2 小时前
扩散模型快速采样:从渐进蒸馏到并行推理
人工智能·算法·加速采样