2026年--Lc331-933. 最近的请求次数(队列)--java版

1.题目


2.思路

首先这道题,需要判断当前t时间点上request请求数是不是在区间[t-300,t]中,并统计该区间有多少个请求。

每次来了一个时间点 t(毫秒),返回最近 3000 毫秒内(包含端点)一共有多少次请求。严格定义是:返回所有满足t−3000≤x≤t的请求时间 x 的数量。(左闭右闭)


3.代码实现

java 复制代码
class RecentCounter {
    Queue<Integer> queue;

    public RecentCounter() {
       queue=new ArrayDeque<Integer>();
        
    }
    
    public int ping(int t) {
//         queue.offer(t) / queue.add(t)(你说的 "push(t)" 一般指这个)

// 作用:把元素 t 放进队列尾部(入队)

// 常见写法:

// queue.offer(t)(更推荐,失败返回 false)

// queue.add(t)(失败会抛异常)
    queue.offer(t);
//     queue.peek():查看队头元素(最早的请求时间),但不删除。 t - 3000:当前时间 t 的窗口左边界(最近 3000ms 的起点)。如果队头时间 严格小于 左边界,说明它落在窗口外
    while(queue.peek()<t-3000)
    {
     queue.poll();
    }
    return queue.size();
    }
      
}

/**
 * Your RecentCounter object will be instantiated and called as such:
 * RecentCounter obj = new RecentCounter();
 * int param_1 = obj.ping(t);
 */
相关推荐
小江的记录本5 小时前
【Java基础】核心关键字:final、static、volatile、synchronized、transient(附《思维导图》+《面试高频考点清单》)
java·前端·数据结构·后端·ai·面试·ai编程
tongluowan0075 小时前
Java 内存模型(JMM)- 内存屏障
java·内存模型·内存屏障
月落归舟5 小时前
并发编程之volatile深度解析(二)
java·开发语言·volatile
me8325 小时前
【AI】踩坑LangChain4j集成千问模型:版本适配问题完整解决历程
java·spring·阿里云·ai
来恩10035 小时前
Java Web三大作用域对象
java·开发语言·前端
ゆづき5 小时前
Java 初学者入门指南:常见问题 + 核心知识点 + 进阶 20 道练习题
java·开发语言·学习·算法·水题
_Evan_Yao5 小时前
限流的艺术:令牌桶与滑动窗口的博弈,以及我为何在 AI 项目中选择了后者
java·后端·架构
LIUAWEIO6 小时前
接口 data 满屏反斜杠,怎么展开?
java·开发语言·数据库·json在线解析·data是字符串·json转义·二次json
吴声子夜歌6 小时前
状态机——Spring State Machine
java·后端·spring