不进行替换的滚动最小值
创始人
2024-12-25 22:02:41
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

相关内容

热门资讯

iwatch怎么连接安卓系统,... 你有没有想过,那款时尚又实用的iWatch,竟然只能和iPhone好上好?别急,今天就来给你揭秘,怎...
安卓系统怎么连不上carlif... 安卓系统无法连接CarLife的原因及解决方法随着智能手机的普及,CarLife这一车载互联功能为驾...
iphone系统与安卓系统更新... 最近是不是你也遇到了这样的烦恼?手机更新系统总是失败,急得你团团转。别急,今天就来给你揭秘为什么iP...
oppo手机安卓系统换成苹果系... OPPO手机安卓系统换成苹果系统:现实吗?如何操作?随着智能手机市场的不断发展,用户对于手机系统的需...
安卓平板改windows 系统... 你有没有想过,你的安卓平板电脑是不是也能变身成Windows系统的超级英雄呢?想象在同一个设备上,你...
安卓换鸿蒙系统会卡吗,体验流畅... 最近手机圈可是热闹非凡呢!不少安卓用户都在议论纷纷,说鸿蒙系统要来啦!那么,安卓手机换上鸿蒙系统后,...
安卓系统上滑按键,便捷生活与高... 你有没有发现,现在手机屏幕越来越大,操作起来却越来越方便了呢?这都得归功于安卓系统上的那些神奇的上滑...
安卓系统连接耳机模式,蓝牙、有... 亲爱的手机控们,你们有没有遇到过这种情况:手机突然变成了“耳机模式”,明明耳机没插,声音却只从耳机孔...
安装了Anaconda之后找不... 在安装Anaconda后,如果找不到Jupyter Notebook,可以尝试以下解决方法:检查环境...
希沃系统怎么装安卓系统,解锁更... 亲爱的读者们,你是否也像我一样,对希沃一体机上的安卓系统充满了好奇呢?想象在教室里,你的希沃一体机不...