不进行替换的滚动最小值
创始人
2024-12-25 22:01:06
0

以下是一个不进行替换的滚动最小值的解决方法的代码示例:

def find_min(nums, k):
    n = len(nums)
    result = []
    window = []

    # 初始化滑动窗口
    for i in range(k):
        while window and nums[i] < nums[window[-1]]:
            window.pop()
        window.append(i)

    # 处理剩余元素
    for i in range(k, n):
        result.append(nums[window[0]])

        # 移除滑动窗口中已经离开的元素
        while window and window[0] <= i - k:
            window.pop(0)

        # 添加当前元素到滑动窗口中
        while window and nums[i] < nums[window[-1]]:
            window.pop()
        window.append(i)

    result.append(nums[window[0]])

    return result

# 测试示例
nums = [4, 3, 5, 4, 3, 3, 6, 7]
k = 3
print(find_min(nums, k))  # 输出: [3, 3, 3, 3, 3, 3]

该方法使用滑动窗口的思想,维护一个递增的双端队列window来保存当前滑动窗口中的最小值的索引。在初始化滑动窗口时,从左到右遍历前k个元素,将大于等于当前元素的索引从队尾弹出,再将当前元素的索引加入队尾。然后,从第k个元素开始遍历,每次都将滑动窗口中的最小值加入结果列表result,然后移除滑动窗口中已经离开的元素的索引,并将大于等于当前元素的索引从队尾弹出,再将当前元素的索引加入队尾。最后,返回结果列表result

相关内容

热门资讯

科普攻略!德普之星辅助器app... 科普攻略!德普之星辅助器app,we poker辅助器,德州论坛(有挂软件)是一款可以让一直输的玩家...
重大科普!佛手在线大菠萝智能辅... 重大科普!佛手在线大菠萝智能辅助器,wepoker作弊辅助,分享教程(有挂软件);原来确实真的有挂(...
一分钟教会你!wepoker怎... 一分钟教会你!wepoker怎么增加运气,epoker透视,切实教程(有挂透视)1、点击下载安装,微...
六分钟了解!hhpoker有辅... 六分钟了解!hhpoker有辅助吗,wepoker国外版透视,扑克教程(有挂技巧)科技教程也叫必备教...
我来教大家!wepoker辅助... 我来教大家!wepoker辅助透视,wepoker免费脚本弱密码,详细教程(有挂透明);wepoke...
记者发布!wpk辅助,德普之星... 记者发布!wpk辅助,德普之星透视辅助软件激活码,解密教程(有挂辅助);亲真的是有正版授权,小编(透...
揭秘攻略!aapoker万能辅... 《揭秘攻略!aapoker万能辅助器,hhpoker真的假的,揭秘教程(有挂教程)》 aapoker...
重大通报!sohoo poke... 自定义sohoo poker辅助器系统规律,只需要输入自己想要的开挂功能,一键便可以生成出微扑克专用...
三分钟了解!wpk辅助器,hh... 1、三分钟了解!wpk辅助器,hhpoker免费辅助器,必赢教程(有挂神器);详细教程。2、hhpo...
玩家必看攻略!wejoker私... 玩家必看攻略!wejoker私人辅助软件,智星德州可以透视吗,透明挂教程(有挂技巧)关于智星德州可以...