POJ2559 Largest Rectangle in a Histogram

这道题一看我们可以发现一个木桶原理,只要有一个短的,长的就没用了,我们就可以维护一个单调栈,如果碰到比前面小的,就直接进行统计和修改,最后再设n+1个矩形高度为0来统计,注意清零

复制代码
#include<bits/stdc++.h>
using namespace std;
int st[100005],w[100005],s[100005],top,a[100005],n;
long long ans;
int main(){
    while(scanf("%d",&n)==1&&n){
        int k;
        for(int i=1;i<=n;i++)
         scanf("%d",&a[i]);
        top=a[n+1]=0;//巧设
        ans=0;
        for(int i=1;i<=n+1;i++){
            if(a[i]>s[top])
             w[++top]=1,s[top]=a[i];//单调性
            else{
             int wid=0;
             while(s[top]>a[i]){
                 wid+=w[top];
                 ans=max(ans,(long long)wid*s[top]);//统计
                 top--; 
             }
             s[++top]=a[i];w[top]=wid+1;
            }
        }
        cout<<ans<<endl;
    }
}
复制代码

 

posted @   Coder_cjh  阅读(112)  评论(0编辑  收藏  举报
编辑推荐:
· 35岁程序员的中年求职记:四次碰壁后的深度反思
· 继承的思维:从思维模式到架构设计的深度解析
· 如何在 .NET 中 使用 ANTLR4
· 后端思维之高并发处理方案
· 理解Rust引用及其生命周期标识(下)
阅读排行:
· 35岁程序员的中年求职记:四次碰壁后的深度反思
· ShadowSql之.net sql拼写神器
· 无需WebView,Vue也能开发跨平台桌面应用
· 使用MCP C# SDK开发MCP Server + Client
· 感觉程序员要被 AI 淘汰了?学什么才有机会?
点击右上角即可分享
微信分享提示