算法练习第六十四天

LCR 184. 设计自助结算系统 - 力扣(LeetCode)

总结:利用一个双端维护队列一个往后递减的队列,对头是最大值,每次进入一个新值时就一直和队尾元素比较将比新的值小的数排出,这样能保证留在队列中的数都是会对最大值产生影响的数,而当主队列中将要排出的数与双端队列对头数相等时则也要将双端队列队头数排出,否则会对主队列中最大的数产生影响。

代码:

cpp 复制代码
class Checkout {
    queue<int> que;
    deque<int> d;
    
public:
    Checkout() {
        
    }
    
    int get_max() {
        if(d.empty())
        {
            return -1;
        }
        return d.front();
    }
    
    void add(int value) {
        while(!d.empty() && value >= d.back())
        {
            d.pop_back();
        }
        d.push_back(value);
        que.push(value);
    }
    
    int remove() {
        if(que.empty())
        {
            return -1;
        }
        int temp = que.front();
        if(temp == d.front())
        d.pop_front();
        que.pop();
        
        return temp;
    }
};
相关推荐
星辞树3 分钟前
从计数到预测:深入浅出词向量 (Word Vectors) —— Stanford CS224n 作业实战记录
算法
JarryStudy3 分钟前
自动调优在Triton-on-Ascend中的应用:从参数优化到性能极致挖掘
人工智能·算法·昇腾·cann·ascend c
CoderYanger7 分钟前
递归、搜索与回溯-穷举vs暴搜vs深搜vs回溯vs剪枝:13.子集
java·算法·leetcode·机器学习·剪枝·1024程序员节
黑客思维者12 分钟前
底层冗余性原理探秘模型剪枝(Pruning)为何能“无损”压缩模型?
算法·机器学习·剪枝
疯疯癫癫才自由21 分钟前
爬取Leetcode Hot 100 题单
算法·leetcode
WolfGang00732124 分钟前
代码随想录算法训练营Day33 | 322.零钱兑换、279.完全平方数、139.单词拆分、背包总结
算法
CoderYanger27 分钟前
递归、搜索与回溯-综合练习:28.不同路径Ⅲ
java·算法·leetcode·深度优先·1024程序员节
我发在否29 分钟前
Rust > 牛客OJ在线编程常见输入输出练习场
算法·rust
忆湫淮30 分钟前
ENVI 5.6 利用现场标准校准板计算地表反射率具体步骤
大数据·人工智能·算法
Ayanami_Reii33 分钟前
基础数据结构应用-一个简单的整数问题
数据结构·算法·树状数组·fenwick tree