题解 | 【模板】滑动窗口

【模板】滑动窗口

https://www.nowcoder.com/practice/be419f584a3f4c5b818833f1ce856626

from collections import deque
import sys
n, k = map(int, sys.stdin.readline().split())
num = list(map(int, sys.stdin.readline().split()))
dq = deque()
ans = []

for i in range(n):
    while dq and num[i] >= num[dq[-1]]:
        dq.pop()
    dq.append(i)
    while dq and dq[0] <= i-k:
        dq.popleft()
    if i >= k-1:
        ans.append(num[dq[0]])
print(' '.join(map(str,ans)))

全部评论

相关推荐

04-27 15:01
早稲田大学 Java
牛客72191338...:可能是时间点的问题,四月底机会确实会相对少点,但佬这个学历摆在这,会有机会的
简历中的项目经历要怎么写
点赞 评论 收藏
分享
05-30 15:29
佛山大学 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务