当从建筑物 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;
}
};