题解 | #生成窗口最大值数组#

生成窗口最大值数组

http://www.nowcoder.com/practice/b316c7f9617744b98fa311ae29ac516c

n, k = map(int, input().split())
nums = list(map(int, input().split()))
import collections
stack = collections.deque()
res = []
for i in range(k):
    while stack and stack[-1] < nums[i]:
        stack.pop()
    stack.append(nums[i])
res.append(stack[0])
for i in range(k, n):
    if nums[i - k] == stack[0]:
        stack.popleft()
    while stack and stack[-1] < nums[i]:
        stack.pop()
    stack.append(nums[i])
    res.append(stack[0])
print(*res)
    
全部评论

相关推荐

程序员花海:实习和校招简历正确格式应该是教育背景+实习+项目经历+个人评价 其中项目经历注意要体现业务 实习经历里面的业务更是要自圆其说 简历模板尽可能保持干净整洁 不要太花哨的
985本硕1个中小厂of...
点赞 评论 收藏
分享
11-30 18:33
已编辑
惠州学院 后端工程师
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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