算法训练营之直方图最大面积

时间限制:1 sec

空间限制:256 MB

问题描述

有一个直方图,横轴长度为 n,第 i 列的高度为 h[i]。

请你求出在这个直方图中面积最大的子矩阵。

输入格式

第一行一个正整数 n。

第二行 n 个用空格隔开的非负整数,依次描述 h[1],h[2],…,h[n]。

输出格式

输出一行一个数,表示最大面积。

样例输入

5
2 3 3 3 2

样例输出

10

数据范围

对于 30% 的测试点,保证 n<=4。

对于 70% 的测试点,保证 n<=1000。

对于所有测试点,保证 n<=50000。

保证所有 h[i] 不超过 32767。

 

思路:利用栈,当高度H单调增时入栈,遇到下降情况重复将栈顶元素弹出,直至碰见<=m[k]的元素为止,过程中对应的每一个H即为矩形高。(注意在最后放置哨兵)

 

C++实现:

#include<stdio.h>
#include<stack>
#define maxn 50050
using namespace std;
int calculate(int m[],int n);


int main(){
int n,ans;
int m[maxn];
scanf("%d",&n);
for(int i = 0;i<n;i++){
    scanf("%d",&m[i]);
}
m[n]=-1;
ans =calculate(m,n);
printf("%d",ans);

return 0;
}



int calculate(int m[],int n){
int maxrect = 0, rect = 0, k=0;
stack<int> s;
while(k <= n){
    if(s.empty() || m[k] >= m[s.top()]){s.push(k); k++;}
    else {
            int h = s.top();
            s.pop();
            if(s.empty()) rect = k * m[h];
            else rect = m[h] * (k - s.top() - 1);//注意此处为什么是s.top()而不是h
			maxrect = max(rect,maxrect);
		}
	}
	
return maxrect;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值