Given n non-negative integers representing the histogram’s bar height where the width of each bar is 1, find the area of largest rectangle in the histogram.
Above is a histogram where width of each bar is 1, given height =[2,1,5,6,2,3].
The largest rectangle is shown in the shaded area, which has area =10unit.
For example,
Given height =[2,1,5,6,2,3],
return10.
class Solution {
public:
int largestRectangleArea(vector<int> &height)
{
stack<int> s;
int ans = 0;
for(int i=0; i<height.size(); i++)
{
int cnt = 0;
if(s.empty() || s.top() <= height[i])
{
s.push(height[i]);
}
else
{
while(!s.empty() && s.top() > height[i])
{
++cnt;
ans = max(ans, cnt * s.top());
s.pop();
}
while(cnt--)
s.push(height[i]);
s.push(height[i]);
}
}
int cnt = 1;
while(!s.empty())
{
ans = max(ans, cnt * s.top());
++cnt;
s.pop();
}
return ans;
}
};