循环队列

机器翻译

#include <algorithm>
#include <fstream>
#include <iostream>
#include <map>
#include <memory>
#include <set>
#include <string>
#include <vector>

#define DEBUG
using namespace std;

template <typename T>
class CircularQueue {
 private:
  T *arr;
  int front;
  int rear;
  int maxSize;

 public:
  CircularQueue(int size) : maxSize(size + 1), front(0), rear(0) {
    arr = new T[maxSize];
  }

  ~CircularQueue() { delete[] arr; }

  bool isEmpty() const { return front == rear; }

  bool isFull() const { return (rear + 1) % maxSize == front; }

  void enqueue(const T &item) {
    if (isFull()) {
      std::cout << "Queue is full. Cannot enqueue." << std::endl;
      return;
    }
    arr[rear] = item;
    rear = (rear + 1) % maxSize;
  }

  void dequeue() {
    if (isEmpty()) {
      std::cout << "Queue is empty. Cannot dequeue." << std::endl;
      return;
    }
    front = (front + 1) % maxSize;
  }

  int size() { return (rear - front + maxSize) % maxSize; }

  T &frontItem() {
    if (isEmpty()) {
      throw std::runtime_error("Queue is empty.");
    }
    return arr[front];
  }
};

int main() {
  ios::sync_with_stdio(false);
  cin.tie(nullptr);
#ifdef DEBUG
  ifstream inputFile("in.txt");
  if (inputFile.is_open()) {
    cin.rdbuf(inputFile.rdbuf());
  }
#endif
  using i64 = long long;

  int m, n;
  cin >> m >> n;
  int cnt = 0;
  vector<bool> st(1001);
  CircularQueue<int> Q(m);
  while (n--) {
    int x;
    cin >> x;
    if (!st[x]) {
      cnt++;
      if (Q.size() == m) {
        int tmp = Q.frontItem();
        Q.dequeue();
        st[tmp] = false;
      }
      Q.enqueue(x);
      st[x] = true;
    }
  }
  cout << cnt << '\n';
}
posted @   hacker_dvd  阅读(8)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示