1 Star 0 Fork 0

wu-xjg/LeetCode

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
Code239.java 1.12 KB
一键复制 编辑 原始数据 按行查看 历史
wu-xjg 提交于 2025-02-17 17:06 +08:00 . day01
package Code;
import java.util.*;
import java.util.stream.Collectors;
import java.util.stream.IntStream;
public class Code239 {
static int[] maxWindow(int[] nums, int k){
if(nums == null || nums.length == 0 || k<=0) {
return new int[0];
}
int n = nums.length;
int[] res = new int[n-k +1];
Deque<Integer> q = new LinkedList<>();
for(int i = 0; i< n; i++){
if(!q.isEmpty() && q.peekFirst()< i-k+1){
q.pollFirst();// 移除队列中不在当前窗口内的元素
}
while(!q.isEmpty() && nums[q.peekLast()]< nums[i]){ // 移除队列中比当前元素小的元素
q.pollLast();
}
q.offer(i);
if(i >=k-1){
res[i-k+1] = nums[q.peekFirst()];
}
}
return res;
}
public static void main(String[] args) {
System.out.println(IntStream.of(maxWindow(new int[]{1, 3, -1, -3, 5, 3, 6, 7}, 3)).boxed().toList());
System.out.println(Arrays.stream(maxWindow(new int[]{1, 3, -1, -3, 5, 3, 6, 7}, 3)).boxed().toList());
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/wu-xjg/leet-code.git
git@gitee.com:wu-xjg/leet-code.git
wu-xjg
leet-code
LeetCode
master

搜索帮助