RecentCounter 类来计算特定时间范围内最近的请求。RecentCounter 类:
RecentCounter() 初始化计数器,请求数为 0。int ping(int t) 在时间 t 添加一个新请求,其中 t 表示以毫秒为单位的某个时间,并返回过去 3000 毫秒内发生的所有请求数(包括新请求)。
[t-3000, t] 内发生的请求数。ping 的调用都使用比之前更大的 t 值。ping(t) 的时候,不断判断队列头节点的时间,如果时间低于 t-3000,则弹出头节点。class RecentCounter
{
private:
queue<int> q;
public:
RecentCounter() {}
int ping(int t)
{
q.push(t);
while(q.front() < t - 3000)
q.pop();
return q.size();
}
};