zoukankan      html  css  js  c++  java
  • LeetCode | 面试题59

    请定义一个队列并实现函数 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_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
    

    方法一:双队列模拟滑动窗口

    class MaxQueue {
    public:
        queue<int> nums; 
        deque<int> q;
    
        MaxQueue() {
            
        }
        
        int max_value() {
            if (q.empty()) return -1;
            return q.front();
        }
        
        void push_back(int value) {
            nums.push(value);
            while(!q.empty() && value > q.back()){
                q.pop_back();
            }
            q.push_back(value);
        }
        
        int pop_front() {
            if (q.empty()) return -1;
            int f = nums.front();
            nums.pop();
            if (f == q.front()){
                q.pop_front();
            }
            return f;
        }
    };
    

    耗时达到220ms了。。。

    方法二:时间优化

    class MaxQueue {
    public:
        MaxQueue() {
    
        }
        
        int max_value() {
            return que.empty()?-1:dq.front();
        }
        
        void push_back(int value) {
            que.push(value);
            while(!dq.empty()&&dq.back()<value)
                dq.pop_back();
            dq.push_back(value);
        }
        
        int pop_front() {
            if(que.empty())
                return -1;
            int t=que.front();
            que.pop();
            if(t==dq.front())
                dq.pop_front();
            return t;
        }
    private:
        queue<int> que;
        deque<int> dq;
    };
    

    稍微优化了以后用时花费140ms

  • 相关阅读:
    转: sql语句获取本周、本月数据
    Java 程序中的静态代码块
    Java 控制台程序输出计时器代码
    网页出现“繁体字”?
    html5中video视频只有声音没有图像
    Clipboard 剪辑板
    区分window8中 ie10 window phone8
    void 0
    touch pointer
    全局作用域 eval
  • 原文地址:https://www.cnblogs.com/RioTian/p/12432984.html
Copyright © 2011-2022 走看看