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);
 */
相关推荐
程序员清风9 小时前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试
皮皮林55110 小时前
利用闲置 Mac 从零部署 OpenClaw 教程 !
java
华仔啊16 小时前
挖到了 1 个 Java 小特性:var,用完就回不去了
java·后端
SimonKing16 小时前
SpringBoot整合秘笈:让Mybatis用上Calcite,实现统一SQL查询
java·后端·程序员
日月云棠1 天前
各版本JDK对比:JDK 25 特性详解
java
用户8307196840821 天前
Spring Boot 项目中日期处理的最佳实践
java·spring boot
JavaGuide1 天前
Claude Opus 4.6 真的用不起了!我换成了国产 M2.5,实测真香!!
java·spring·ai·claude code
IT探险家1 天前
Java 基本数据类型:8 种原始类型 + 数组 + 6 个新手必踩的坑
java
花花无缺1 天前
搞懂new 关键字(构造函数)和 .builder() 模式(建造者模式)创建对象
java
用户908324602731 天前
Spring Boot + MyBatis-Plus 多租户实战:从数据隔离到权限控制的完整方案
java·后端