LeetCode | 面试题59 - II. 队列的最大值【Python】

LeetCode 面试题59 - II. 队列的最大值【Medium】【Python】【队列】

问题

力扣

请定义一个队列并实现函数 max_value 得到队列里的最大值,要求函数max_valuepush_backpop_front均摊时间复杂度都是O(1)。

若队列为空,pop_frontmax_value 需要返回 -1

示例 1:

输入:
["MaxQueue","push_back","push_back","max_value","pop_front","max_value"]
[[],[1],[2],[],[],[]]
输出: [null,null,null,2,1,2]

示例 2:

输入:
["MaxQueue","pop_front","max_value"]
[[],[],[]]
输出: [null,-1,-1]

限制:

  • 1 <= push_back,pop_front,max_value的总操作数 <= 10000
  • 1 <= value <= 10^5

思路

辅助队列

sort_que 队列的头部永远是 que 队列的最大值。

时间复杂度: O(1)

Python3代码
from collections import deque

class MaxQueue:

    def __init__(self):
        self.que = deque()
        self.sort_que = deque()

    def max_value(self) -> int:
        return self.sort_que[0] if self.sort_que else -1

    def push_back(self, value: int) -> None:
        self.que.append(value)
        # sort_que: non-increasing 非递增
        while self.sort_que and self.sort_que[-1] < value:
            self.sort_que.pop()
        self.sort_que.append(value)

    def pop_front(self) -> int:
        if not self.que:
            return -1
        res = self.que.popleft()  # popleft(): O(1), pop(i): O(n)
        if res == self.sort_que[0]:
            self.sort_que.popleft()
        return res

# Your MaxQueue object will be instantiated and called as such:
# obj = MaxQueue()
# param_1 = obj.max_value()
# obj.push_back(value)
# param_3 = obj.pop_front()

代码地址

GitHub链接

参考

【Python】详解:为何添加辅助队列就能实现O(1)操作?

原文地址:https://www.cnblogs.com/wonz/p/12442121.html

时间: 2024-07-30 09:20:12

LeetCode | 面试题59 - II. 队列的最大值【Python】的相关文章

[LeetCode] 面试题59 - II. 队列的最大值

题目: 分析: 本题要求三个方法的时间复杂度都是O(1),对于push_back和pop_front都是好实现的 但是对于max_value,正常情况下要进行遍历才能获得最大值,那么如何才能在O(1)的时间复杂度下获得最大值? O(1)时间复杂度意味着直接便可以获得最大值,一开始的想法是设置两个变量,一个最大值max,一个第二大值max_2,每次push_back时进行更新,若pop_front的值与最大值相同,便让max = max_2 但这样有个问题,当连续两次pop_front,同时前两大

【LeetCode】面试题59 - II. 队列的最大值

题目链接: 面试题59 - II. 队列的最大值 题目描述: 请定义一个队列并实现函数 max_value 得到队列里的最大值,要求函数 max_value.push_back 和 pop_front 的时间复杂度都是 O(1). 若队列为空,pop_front 和 max_value 需要返回 -1. 示例: 示例 1: 输入: ["MaxQueue","push_back","push_back","max_value",

【剑指Offer】面试题59 - II. 队列的最大值

题目 请定义一个队列并实现函数 max_value 得到队列里的最大值,要求函数max_value.push_back 和 pop_front 的均摊时间复杂度都是O(1). 若队列为空,pop_front 和 max_value?需要返回 -1 示例 1: 输入: ["MaxQueue","push_back","push_back","max_value","pop_front","max_v

面试题59 - II.:队列的最大值(C++)

题目地址:https://leetcode-cn.com/problems/dui-lie-de-zui-da-zhi-lcof/ 题目描述 请定义一个队列并实现函数 max_value 得到队列里的最大值,要求函数max_value.push_back 和 pop_front 的均摊时间复杂度都是O(1). 若队列为空,pop_front 和 max_value 需要返回 -1 题目示例 示例 1: 输入: ["MaxQueue","push_back",&quo

剑指OFFER----面试题59 - II. 队列的最大值

链接:https://leetcode-cn.com/problems/dui-lie-de-zui-da-zhi-lcof/ 代码 class MaxQueue { public: queue<int> q; deque<int> d; MaxQueue() { } int max_value() { if (d.empty()) return -1; return d.front(); } void push_back(int value) { while (!d.empty(

LeetCode——面试题57 - II. 和为s的连续正数序列

输入一个正整数 target ,输出所有和为 target 的连续正整数序列(至少含有两个数). 序列内的数字由小到大排列,不同序列按照首个数字从小到大排列. 示例 1: 输入:target = 9 输出:[[2,3,4],[4,5]] 示例 2: 输入:target = 15 输出:[[1,2,3,4,5],[4,5,6],[7,8]] 限制: 1 <= target <= 10^5 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/he

leetcode面试题59

双端队列 实际上就是一个每次push pop的常规queue和另一个首位是最大值的queue type MaxQueue struct { Queue []int Max []int Size int } func Constructor() MaxQueue { return MaxQueue{ Queue: []int{}, Max: []int{}, Size: 0, } } func (this *MaxQueue) Max_value() int { if this.Size == 0

菜鸟系列 Golang 实战 Leetcode —— 面试题57 - II. 和为s的连续正数序列

输入一个正整数 target ,输出所有和为 target 的连续正整数序列(至少含有两个数). 序列内的数字由小到大排列,不同序列按照首个数字从小到大排列. ? 示例 1: 输入:target = 9 输出:[[2,3,4],[4,5]] 示例 2: 输入:target = 15 输出:[[1,2,3,4,5],[4,5,6],[7,8]] ? 限制: 1 <= target <= 10^5 题解1: 采用滑动窗口,设置左右两个指针,如果sum为target,则保存双指针内的值,如果sum&

《剑指offer》第五十九题II:队列的最大值

// 面试题59(二):队列的最大值 // 题目:给定一个数组和滑动窗口的大小,请找出所有滑动窗口里的最大值.例如, // 如果输入数组{2, 3, 4, 2, 6, 2, 5, 1}及滑动窗口的大小3,那么一共存在6个 // 滑动窗口,它们的最大值分别为{4, 4, 6, 6, 6, 5}, #include <cstdio> #include <deque> #include <exception> using namespace std; template<