【数据结构-单调队列】力扣LCR 184. 设计自助结算系统

请设计一个自助结账系统,该系统需要通过一个队列来模拟顾客通过购物车的结算过程,需要实现的功能有:

get_max():获取结算商品中的最高价格,如果队列为空,则返回 -1

add(value):将价格为 value 的商品加入待结算商品队列的尾部

remove():移除第一个待结算的商品价格,如果队列为空,则返回 -1

注意,为保证该系统运转高效性,以上函数的均摊时间复杂度均为 O(1)

示例 1:

输入:

"Checkout","add","add","get_max","remove","get_max"

\[\],\[4\],\[7\],\[\],\[\],\[\]

输出: [null,null,null,7,4,7]

示例 2:

输入:

"Checkout","remove","get_max"

\[\],\[\],\[\]

输出: [null,-1,-1]

提示:

1 <= get_max, add, remove 的总操作数 <= 10000

1 <= value <= 10^5

代码

csharp 复制代码
class Checkout {
public:
    queue<int> q;
    deque<int> d;
    Checkout() {
        
    }
    
    int get_max() {
        if(d.empty()){
            return -1;
        }
        return d.front();
    }
    
    void add(int value) {
        while(!d.empty() && d.back() < value){
            d.pop_back();
        }
        d.push_back(value);
        q.push(value);
    }
    
    int remove() {
        if(q.empty()){
            return -1;
        }
        int ans = q.front();
        if(ans == d.front()){
            d.pop_front();
        }
        q.pop();
        return ans;
    }
};

这道题难度不大,我们只需要定义一个普通的队列来找到第一个未结算的商品,然后定义一个单调递减的双端序列用队头元素来表示获取结算商品中的最高价格即可。

相关推荐
.小墨迹9 小时前
局部规划中的TEB,DWA,EGOplanner等算法在自动驾驶中应用?
开发语言·c++·人工智能·学习·算法·机器学习·自动驾驶
AI科技星9 小时前
张祥前统一场论 22 个核心公式及常数
服务器·人工智能·线性代数·算法·矩阵·概率论
苏婳6669 小时前
阿里巴巴校招软件笔试题经典
算法
阿猿收手吧!9 小时前
【数据结构】高效掌握并查集:核心原理与实战
数据结构·算法
励ℳ9 小时前
机器学习之线性回归算法:从原理到实践的全面解析
算法·机器学习·线性回归
_Twink1e9 小时前
[算法教学]一、前置知识
算法
MicroTech20259 小时前
微算法科技(NASDAQ: MLGO)使用量子傅里叶变换(QFT),增强图像压缩和滤波效率
科技·算法·量子计算
㓗冽9 小时前
矩阵问题(二维数组)-基础题70th + 发牌(二维数组)-基础题71th + 数字金字塔(二维数组)-基础题72th
c++·算法·矩阵
芜湖xin9 小时前
【题解-Acwing】796. 子矩阵的和
算法·前缀和
shehuiyuelaiyuehao9 小时前
23七大排序算法
数据结构·算法·排序算法