# Furthest Building You Can Reach

# Problem Statement:-

You are given an integer array of heights representing the heights of buildings, some bricks, and some ladders.

You start your journey from building 0 and move to the next building by possibly using bricks or ladders.

While moving from building i to building i+1 (0-indexed),

If the current building's height is greater than or equal to the next building's height, you do not need a ladder or bricks. If the current building's height is less than the next building's height, you can either use one ladder or (h[i+1] - h[i]) bricks. Return the furthest building index (0-indexed) you can reach if you use the given ladders and bricks optimally.

Example 1:-

Input: heights = [4,2,7,6,9,14,12], bricks = 5, ladders = 1

Output: 4

Explanation: Starting at building 0, you can follow these steps:

Go to building 1 without using ladders nor bricks since 4 >= 2.

Go to building 2 using 5 bricks. You must use either bricks or ladders because 2 < 7.

Go to building 3 without using ladders nor bricks since 7 >= 6.

Go to building 4 using your only ladder. You must use either bricks or ladders because 6 < 9.

It is impossible to go beyond building 4 because you do not have any more bricks or ladders.

# Approach:-

The underlying concept is greedy. We first try to use bricks and then ladders.Since ladders are more "powerful" than the bricks. When we meet a high building we first try to use the bricks. If we no longer have the required no. of bricks we have to use the ladder. We can imagine Time Traveling to the part where we have used the maximum no. of bricks and take back those bricks and using the ladder there. Such that the gained bricks can be used the travel ahead in our path.

```
class Solution {
public:
int furthestBuilding(vector<int>& heights, int bricks, int ladders) {
priority_queue<int> pq; //Max Heap
int cB = 0,lad=ladders,n = heights.size();
for(int i=1;i<n;i++)
{
if(heights[i]>heights[i-1])
{
int diff = heights[i]-heights[i-1];
cB += diff; //Current No. Of Bricks Required
pq.push(diff);
if(cB>bricks) //If required no. of bricks exceeds the
{ //available bricks
if(lad>0)
{
//Since we have ladder left, we can either directly
//use it here or we can imagine that we can travel back
//to the part where we have used the maximum no. of bricks
//use the ladder there and take back those bricks such
//that we can use them here.
cB-=pq.top();
pq.pop();
lad--;
}
else
{
return i-1;
}
}
}
}
//We reached the last building
return n-1;
}
};
```