机器翻译
#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';
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现