<span>2019牛客暑期多校训练营(第八场)A 单调栈</span>

题意

给一个\(n*m\)的01矩阵,找有多少个全1子矩阵不被其他全1子矩阵包括。

分析

用单调栈找到的全1子矩阵是不能向上扩展和向右扩展的,只需判断该子矩阵能否向左和向下扩展,若四个方向都不能扩展,则该矩阵合法。是否能向左扩展可用预处理出的左边一列的高度是否大于等于该子矩阵的高度判断,是否能向下扩展可用前缀和判断下面一段是否全1。

Code

#include<bits/stdc++.h>
#define fi first
#define se second
#define pb push_back
#define ll long long
using namespace std;
const int inf=1e9;
const int mod=1e9+7;
const int maxn=1e5+10;
int n,m;
int a[3010][3010],h[3010][3010],sum[3010][3010];
int l[3010],r[3010],sta[3010],ans;
void solve(int R){
    int top=0,cur;
    for(int j=1;j<=m+1;j++){
        cur=sta[top];
        while(top&&h[R][cur]>h[R][j]){
            r[cur]=j-1;
            --top;
            cur=sta[top];
        }
        l[j]=cur+1;
        sta[++top]=j;
    }
    for(int j=1;j<=m;j++){
        if(a[R][j]&&sum[R+1][r[j]]-sum[R+1][l[j]-1]!=r[j]-l[j]+1&&h[R][l[j]-1]<h[R][j]) ans++;
    }
}
int main(){
    scanf("%d%d",&n,&m);
    for(int i=1;i<=n;i++){
        for(int j=1;j<=m;j++){
            scanf("%1d",&a[i][j]);
        }
    }
    for(int i=1;i<=n;i++){
        for(int j=1;j<=m;j++){
            if(a[i][j]) h[i][j]=h[i-1][j]+a[i][j];
            sum[i][j]=sum[i][j-1]+a[i][j];
        }
    }
    for(int i=1;i<=n;i++) solve(i);
    printf("%d\n",ans);
    return 0;
}
全部评论

相关推荐

牛客44320985...:你的当务之急是把这个糖的要死的沟槽ide主题改了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 春招至今,你的战绩如何? #
14007次浏览 132人参与
# AI面会问哪些问题? #
829次浏览 20人参与
# 米连集团26产品管培生项目 #
6914次浏览 223人参与
# 你的实习产出是真实的还是包装的? #
2487次浏览 48人参与
# AI时代,哪个岗位还有“活路” #
2534次浏览 49人参与
# 长得好看会提高面试通过率吗? #
2602次浏览 41人参与
# MiniMax求职进展汇总 #
24660次浏览 313人参与
# 你做过最难的笔试是哪家公司 #
1037次浏览 18人参与
# HR最不可信的一句话是__ #
942次浏览 31人参与
# 沪漂/北漂你觉得哪个更苦? #
954次浏览 29人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
7918次浏览 43人参与
# XX请雇我工作 #
51130次浏览 171人参与
# 简历中的项目经历要怎么写? #
310781次浏览 4252人参与
# 简历第一个项目做什么 #
31991次浏览 354人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152739次浏览 888人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187498次浏览 1123人参与
# AI时代,哪些岗位最容易被淘汰 #
64417次浏览 859人参与
# 如果重来一次你还会读研吗 #
229947次浏览 2011人参与
# 正在春招的你,也参与了去年秋招吗? #
364051次浏览 2640人参与
# 腾讯音乐求职进展汇总 #
160799次浏览 1114人参与
# 你怎么看待AI面试 #
180556次浏览 1290人参与
# 投格力的你,拿到offer了吗? #
178064次浏览 889人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务