其他分享
首页 > 其他分享> > b_lc_可达的最远建筑(pq+贪心实现延迟思想)

b_lc_可达的最远建筑(pq+贪心实现延迟思想)

作者:互联网

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

思路:遇到阶梯时,因为我不知道使用砖块还是楼梯对后面的实现更优,所以我先将阶梯的高度差放入小根堆中,
只有当我无法处理完所有阶梯的时候,我才动用砖块(因为我有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;
    }
};

标签:pq,lc,int,建筑物,高度,阶梯,砖块,梯子,贪心
来源: https://www.cnblogs.com/wdt1/p/13910328.html