题意

给一个\(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;
}

最新文章

  1. MySQL 子查询与连接操作笔记
  2. [NOIP2012]国王游戏 题解
  3. 一段比较有意思的代码——介绍system verilog中的新增幅值语句
  4. nginx应用总结(2)--突破高并发的性能优化
  5. 支持向量机(SVM)
  6. hdu 1081 矩阵最大连续子序列
  7. C#语言基础——定义变量、变量赋值、输入输出
  8. vue-router源码学习(一)
  9. Android开发学习之路--NDK、JNI之初体验
  10. What is volatile?
  11. python 全栈开发,Day19(组合,组合实例,初识面向对象小结,初识继承)
  12. spring cloud: Hystrix(二):简单使用@HystrixCommand的commandProperties配置@HistrixProperty隔离策略
  13. php完美匹配邮箱、链接地址和电话号码
  14. OpenGL ES 3.0之Uniform详解
  15. discuz 修改积分策略( 在周期中添加&quot;每周&quot; )
  16. 所有流媒体协议,编解码规范和媒体封装格式的datasheet的下载地址
  17. Python3 匿名函数
  18. collection 多态 会自动转型为子类 继承多态需要显示转型
  19. LeetCode 700——二叉搜索树中的搜索
  20. 第一篇 Python的数据类型

热门文章

  1. pytest参数化的两种方式
  2. 并不对劲的CF1237D&amp;E:Balanced Playlist and Binary Search Trees
  3. ubutnu18.04LTS 配置网卡新特性
  4. 怎样理解 Vue 的 &quot;Hello, World!&quot; 代码?
  5. 缓存策略:redis缓存之springCache
  6. O037、Rebuild Instance 操作详解
  7. 【Java】 BIO与NIO以及AIO分析
  8. python 列表字典按照字典中某个valu属性进行排序
  9. Delphi10.2.3利用THttpClient实现http异步下载
  10. Linux 下幾種網芳/Samba 目錄的 mount 方式