【东华大学oj】最近的请求次数

最近的请求次数

时间限制: 1s

类别: DS:队列->队列的应用

晚于 2024-05-26 23:59:00 后提交分数乘系数50%

截止日期:2024-05-30 23:59:00

问题描述

写一个 RecentCounter 类来计算特定时间范围内最近的请求。

请你实现 RecentCounter 类并实现main函数,读入测试数据中的指令,调用RecentCounter类中的相应操作以获得结果。

RecentCounter 类至少包含以下操作:

RecentCounter() :构造函数,初始化计数器,请求数为 0 。

int ping(int t): 在时间 t 添加一个新请求,其中 t 表示以毫秒为单位的某个时间,并返回过去 3000 毫秒内发生的所有请求数(包括新请求)。确切地说,返回在 [t-3000, t] 内发生的请求数。

保证每次对 ping 的调用都使用比之前更大的 t 值。

示例 1:

输入(以下输入的是ping的时间t):

[1, 100, 3001, 3002]

输出:

[1, 2, 3, 3]

解释:

RecentCounter recentCounter = new RecentCounter();

recentCounter.ping(1);     // requests = [1],范围是 [-2999,1],返回 1

recentCounter.ping(100);   // requests = [1, 100],范围是 [-2900,100],返回 2

recentCounter.ping(3001);  // requests = [1, 100, 3001],范围是 [1,3001],返回 3

recentCounter.ping(3002);  // requests = [1, 100, 3001, 3002],范围是 [2,3002],返回 3

参考模板:

class RecentCounter {

public:

    RecentCounter() {

    }

    int ping(int t) {

    }

};

输入说明

输入若干行

第一行为一个整数n,表示调用ping的次数

接下来n行输入严格递增的n个整数值t

说明:

1 <= t <= 10^9

1 <= n <= 10^4 

输出说明

输出n行

每行为一个整数,表示ping的返回结果

每一行都没有多余的空格

#include<iostream>
#include<stack>
#include<queue>
using namespace std;

class RecentCounter
{
    queue<int> q; // 用于存储最近的时间戳

public:
    RecentCounter() {}

    int ping(int t)
    {
        q.push(t); // 将当前时间戳加入队列

        // 移除队列中超出时间范围的时间戳
        while (q.front() < t - 3000)
        {
            q.pop();
        }

        return q.size(); // 返回队列中元素个数,即调用次数
    }
};

int main()
{
    int n;
    cin>>n;
    RecentCounter recentCounter;

    for(int i=0; i<n; ++i)
    {
        int k;
        cin>>k;
        cout<<recentCounter.ping(k)<<endl;
    }
    return 0;
}

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ixll625

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值