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++程序设计方法1:分离代码


下一篇:B. Jzzhu and Cities 解析(思維、最短路)