当前位置: 首页 > article >正文

【数据结构-单调队列】力扣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

代码

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;
    }
};

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


http://www.kler.cn/a/466697.html

相关文章:

  • 【数学建模笔记】评价模型-基于熵权法的TOPSIS模型
  • 【情感】程序人生之情感关系中的平等意识(如何经营一段长期稳定的关系 沸羊羊舔狗自查表)
  • 『SQLite』创建、附加、分离、备份及恢复数据库
  • 【Unity3D】UGUI Canvas画布渲染流程
  • [Qt] 输入控件 | Line | Text | Combo | Spin | Date | Dial | Slider
  • 记录一次线上因kafka宕机而导致java服务cpu飙升的情况
  • 24年收尾之作------动态规划<六> 子序列问题(含对应LeetcodeOJ题)
  • 如何在Windows / Mac / Android上查看 HEIC 图像
  • 使用rust加速python的tgz解压
  • Excel-vlookup 函数使用
  • 深入理解计算机系统—虚拟内存(2)
  • 数据库新建用户后(Host:%),报错:localhost无法连接
  • linux下安装tun模块详细教程
  • 基于FPGA的2FSK+帧同步系统verilog开发,包含testbench,高斯信道,误码统计,可设置SNR
  • 算法-大整数反转
  • UE4_用户控件_10_用图像来显示场景捕获的渲染目标
  • 企业三要素如何用PHP实现调用
  • IIS设置IP+端口号外网无法访问的解决方案
  • 【Python系列】Flask 与 FastAPI:两个 Python Web 框架的对比分析
  • 组合模式详解
  • 依赖冲突`npm install --no-audit --save @testing-library/jest-dom@^5.14.1...` failed
  • CTE与子查询的区别及运行效率比较
  • 使用Dockerfile构建镜像
  • centos8 部署 kubernetes集群
  • 网易云的ip归属地是什么意思?为什么变来变去
  • Segment Anything C++ 项目【Part2:修改源码+自动分割】