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);
 */
相关推荐
马士兵教育1 小时前
Java还有前景吗?Java+AI大模型学习路线及项目?
java·人工智能·python·学习·机器学习
snow@li2 小时前
Java:理解 Gradle / 后端项目的管家 / 打包SpringBoot 应用 / 完成编译、下载依赖、运行测试、打包 JAR/WAR / 速查表
java
云烟成雨TD2 小时前
Spring AI 1.x 系列【57】动态工具发现:Tool Search Tool
java·人工智能·spring
zfoo-framework2 小时前
[修改代码使用]codex官方app中使用中转(不需要cc-switch) 1.config.toml 2.sk方式登录
java
逍遥德2 小时前
MQTT教程详解-05.SpringBoot集成mqtt client 性能分析
java·spring boot·spring·mt
云烟成雨TD2 小时前
Spring AI 1.x 系列【54】Retry 机制分析
java·人工智能·spring
weixin_523185322 小时前
Collections.unmodifiableMap详解:真的不可修改吗?
java·linux·前端
点燃大海3 小时前
SpringAI构建智能体
java·spring boot·spring·springai智能体
xier_ran3 小时前
【infra之路】02_RadixAttention与KV_Cache管理
java·spring boot·spring
黑马师兄3 小时前
RAG混合检索深度解析:让AI真正找到你要的内容
java·人工智能·ai·agent·rag·ai-native