力扣622.设计循环队列

力扣622.设计循环队列

    • 通过数组索引构建一个虚拟的首尾相连的环
    • 当front = rear时 队列为空
    • 当front = rear + 1时 队列为满 (最后一位不存)
cpp 复制代码
  class MyCircularQueue {
      int front;
      int rear;
      int capacity;
      vector<int> elements;
  public:
      MyCircularQueue(int k) {
          //最后一位不存元素 多开一个
          capacity = k+1;
          elements = vector<int>(capacity);
          rear = front = 0;
      }
      
      bool enQueue(int value) {
          if(isFull())
              return false;
          elements[rear] = value;
          rear = (rear + 1) % capacity;
          return true;
      }
      
      bool deQueue() {
          if(isEmpty())
              return false;
          front = (front + 1) % capacity;
          return true;
      }
      
      int Front() {
          if(isEmpty())
              return -1;
          return elements[front];
      }
      
      int Rear() {
          if(isEmpty())
              return -1;
          return elements[(rear - 1 + capacity) % capacity];
      }
      
      bool isEmpty() {
          return rear == front;
      }
      
      bool isFull() {
          return ((rear + 1) % capacity) == front;
      }
  };
相关推荐
IronMurphy6 小时前
【算法三十九】994. 腐烂的橘子
算法
迷茫的启明星6 小时前
各职业在当前发展阶段,使用AI的舒适区与盲区
大数据·人工智能·职场和发展
Ares-Wang7 小时前
算法》》旅行商问题 TSP、7座桥问题 哈密顿回路 深度优先 和 宽度优先
算法·深度优先·宽度优先
Liqiuyue7 小时前
Transformer:现代AI革命背后的核心模型
人工智能·算法·机器学习
WolfGang0073217 小时前
代码随想录算法训练营 Day34 | 动态规划 part07
算法·动态规划
Kk.08027 小时前
Linux(十一)fork实例练习、文件操作示例及相关面试题目分享
linux·运维·算法
潇冉沐晴8 小时前
2026CCCC第三次模拟赛 部分题解
算法
WolfGang0073218 小时前
代码随想录算法训练营 Day32 | 动态规划 part05
算法·动态规划
碧海银沙音频科技研究院9 小时前
1-1杰理蓝牙SOC的UI配置开发方法
人工智能·深度学习·算法