zoukankan      html  css  js  c++  java
  • b_lc_可达的最远建筑(pq+贪心实现延迟思想)

    当从建筑物 i 移动到建筑物 i+1(下标 从 0 开始 )时:(1 <= h.length <= 10^5)

    • 如果当前建筑物的高度 大于或等于 下一建筑物的高度,则不需要梯子或砖块
    • 如果当前建筑的高度 小于 下一个建筑的高度,您可以使用 一架梯子 或 (h[i+1] - h[i]) 个砖块

    思路:遇到阶梯时,因为我不知道使用砖块还是楼梯对后面的实现更优,所以我先将阶梯的高度差放入小根堆中,
    只有当我无法处理完所有阶梯的时候,我才动用砖块(因为我有L个梯子保证我可以跳过L个阶梯),但我要尽量更省砖块

    class Solution {
    public:
        int furthestBuilding(vector<int>& h, int b, int l) {
            int n=h.size();
            priority_queue<int, vector<int>, greater<int>> q;
            for (int i=1; i<n; i++) {
                if (h[i-1]<h[i]) {
                    q.push(h[i]-h[i-1]);
                    if (q.size()>l) {
                        b-=q.top();
                        if (b<0) return i-1; //b<0表示我梯子用完,砖块也用完都无法跳过该阶梯;b==0时我还可以走滴,因为后面可能是"一马平川"
                        q.pop();
                    }
                } 
            }
            return n-1;
        }
    };
    
  • 相关阅读:
    C++中的动态内存管理
    Harbor镜像仓库搭建
    nexus私服搭建
    Tekton ACK安装
    容器监控实践,从入门到放弃
    Bitwarden_搭建密码服务器
    Jenkins-部署文档
    Mysql-基本的
    Zabbix添加-钉钉故障报警
    ZABBIX-4.4 yum安装
  • 原文地址:https://www.cnblogs.com/wdt1/p/13910328.html
Copyright © 2011-2022 走看看