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

生成窗口最大值数组

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)
    
全部评论

相关推荐

哞客37422655...:兄弟别慌!💪 民办本找实习确实难点,但不是没机会。100+简历才2个面试,可能简历需要优化下: 项目经历写具体点,突出测试用例、bug数量等 技能栏把测试工具/方法论写清楚 可以考虑降低预期,先进小厂积累经验 测试岗相对好进,坚持投!现在才半个月,有人投3个月才上岸的😭 加油,offer在路上了🚀
点赞 评论 收藏
分享
搞机墨镜猫:参考一下其他人简历吧, 把项目放最上面,没有项目就展开写实习,实习项目具体做了啥,现在很空 奖项写含金量高的,还有校园经历也是,不是运营岗基本上可以都删了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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