描述

给定一个N × M的01矩阵,小Hi希望从中找到一个01间隔的子矩阵,并且子矩阵的面积越大越好。

例如对于

0101010

1000101

0101010

1010101

0101010

在右侧有一个5 × 4的01间隔子矩阵,在下方有一个3 × 7的01间隔子矩阵。

输入

第一行包含两个整数N和M。

以下N行M列包含一个N × M的01矩阵。

对于30%的数据,1 ≤ N, M ≤ 250

对于100%的数据,1 ≤ N, M ≤ 2000

输出

输出最大的01间隔子矩阵的面积。

样例输入

  1. 5 7
  2. 0101010
  3. 1000101
  4. 0101010
  5. 1010101
  6. 0101010

样例输出

  1. 21
  • 模型:滑动窗口,最大广告牌面积
  • 手段:单调队列
  1. #include<cstdio>
  2. #include<cstdlib>
  3. #include<iostream>
  4. #include<cstring>
  5. #include<cmath>
  6. using namespace std;
  7. const int maxn=;
  8. char c[maxn][maxn];
  9. int H[maxn][maxn],L[maxn][maxn],R[maxn][maxn],n,m,i,j,ans=;;
  10. int main()
  11. {
  12. scanf("%d%d",&n,&m);
  13. for(i=;i<=n;i++) scanf("%s",c[i]+);
  14.  
  15. for(i=;i<=m;i++) H[][i]=; //得到h
  16. for(i=;i<=m;i++)
  17. for(j=;j<=n;j++)
  18. H[j][i]=c[j][i]==c[j-][i]?:H[j-][i]+;
  19.  
  20. for(i=;i<=n;i++) //得到相应h的左延伸
  21. for(j=;j<=m;j++){
  22. if(j==) { L[i][j]=;continue;}//边界处理
  23. int k=j;
  24. while(k>&&c[i][k]!=c[i][k-]&&H[i][k-]>=H[i][j]) k=L[i][k-];
  25. L[i][j]=k;
  26. }
  27.  
  28. for(i=;i<=n;i++) //得到相应h的右延伸
  29. for(j=m;j>=;j--){
  30. if(j==m) {R[i][j]=m;continue;}
  31. int k=j;
  32. while(k&&k<m&&c[i][k]!=c[i][k+]&&H[i][k+]>=H[i][j]) k=R[i][k+];
  33. R[i][j]=k;
  34. }
  35.  
  36. for(i=;i<=n;i++)
  37. for(j=;j<=m;j++)
  38. if((R[i][j]-L[i][j]+)*H[i][j]>ans) ans=(R[i][j]-L[i][j]+)*H[i][j];
  39.  
  40. printf("%d\n",ans);
  41. return ;
  42. }

HihoCoder1673 : 01间隔矩阵([Offer收割]编程练习赛41)(单调队列)的更多相关文章

  1. [Offer收割]编程练习赛41

    比赛日程安排 #pragma comment(linker, "/STACK:102400000,102400000") #include<stdio.h> #incl ...

  2. HihoCoder1670 : 比赛日程安排([Offer收割]编程练习赛41)(模拟)

    描述 H国编程联赛中有N只队伍,编号1~N. 他们计划在2018年一共进行M场一(队)对一(队)的比赛. 为了让参赛队员能得到充分的休息,联赛组委会决定:每支队伍连续两场比赛之间至少间隔一天.也就是如 ...

  3. HihoCoder1672 : 区间问题([Offer收割]编程练习赛41)(贪心)

    时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 给定N个区间[Ai, Bi],请你找到包含元素最少的整数集合S,使得每个区间都至少有两个整数在S中. 例如给定三个区间[1 ...

  4. HiHoCoder1671 : 反转子串([Offer收割]编程练习赛41)(占位)

    描述 给定一个只包含括号和小写字母的字符串S,例如S="a(bc(de)fg)hijk". 其中括号表示将里面的字符串翻转.(注意括号可能嵌套) 请你输出翻转之后的字符串. 输入 ...

  5. hihocoder [Offer收割]编程练习赛4

    描述 最近天气炎热,小Ho天天宅在家里叫外卖.他常吃的一家餐馆一共有N道菜品,价格分别是A1, A2, ... AN元.并且如果消费总计满X元,还能享受优惠.小Ho是一个不薅羊毛不舒服斯基的人,他希望 ...

  6. hihocoder [Offer收割]编程练习赛61

    [Offer收割]编程练习赛61 A:最小排列 给定一个长度为m的序列b[1..m],再给定一个n,求一个字典序最小的1~n的排列A,使得b是A的子序列. 贪心即可,b是A的子序列,把不在b中的元素, ...

  7. [Offer收割]编程练习赛46

    [Offer收割]编程练习赛46赛后题解 A.AEIOU 分析

  8. HihoCoder1664 01间隔方阵([Offer收割]编程练习赛40)(DP)

    给定一个NxM的01矩阵,小Hi希望从中找到一个01间隔的子方阵,并且方阵的边长越大越好. 例如对于 0100100 1000101 0101010 1010101 0101010 在右下角有一个4x ...

  9. [Offer收割]编程练习赛40

    不到一个小时AK,虽然是VP的,舒服,第一次.都简单的一比,没什么可说的. 查找三阶幻方 #pragma comment(linker, "/STACK:102400000,10240000 ...

随机推荐

  1. vim 处理换行符

    1. 设置文件格式 :set fileformats=unix,dos 2. 查询当前文件格式 :set fileformat? 3. 转换文件格式 :set fileformat=dos 4. 设置 ...

  2. gulp 静态资源版本控制

    package.json { "name": "gulp", "version": "0.0.1", "des ...

  3. 看完这篇再不会 View 的动画框架,我跪搓衣板

    引言 众所周知,一款没有动画的 app,就像没有灵魂的肉体,给用户的体验性很差.现在的 android 在动画效果方面早已空前的发展,1.View 动画框架 2.属性动画框架 3.Drawable 动 ...

  4. request 防盗链

    package request; import java.io.IOException;import javax.servlet.ServletException;import javax.servl ...

  5. 利用.dSYM跟.app文件准确定位Crash位置

     本文转载至  http://blog.csdn.net/lvxiangan/article/details/28102629       利用.dSYM和.app文件准确定位Crash位置首先,确保 ...

  6. smarty模板里实现缓存。

    smarty模板里实现缓存.分页缓存在任何里都可以用 我用了三个类 include("../init.inc.php");//模板入口类 include("../DBDA ...

  7. android菜鸟学习笔记13----Android控件(二) 自定义控件简单示例

    有时候,可能觉得系统提供的控件太丑,就会需要自定义控件来实现自己想要的效果. 以下主要参考<第一行代码> 1.自定义一个标题栏: 系统自带的标题栏很丑,且没什么大的作用,所以我们之前会在o ...

  8. windowsphone8.1学习笔记之应用数据(一)

    数据存储分为两种:云存储和应用数据(即本地存储),wp中的应用数据分为两种,一种是应用设置:一种是应用文件.wp的数据相关都是通过ApplicationData来实现,一个程序只有数据存储区. 先说应 ...

  9. maven工作的过程

    1 建立各个module之间的依赖关系 2 越底层的依赖的module先生成 3 下载远程库中的依赖 4 先生成本地被依赖的module 问题是,如何保证本次module和远程库中的包不重名?

  10. Asynchronous_method_invocation 异步方法调用 让步 yielding

    zh.wikipedia.org/wiki/同步 [同步不同事件发生 时间一致] 同步(英语:Synchronization),指在一个系统中所发生的事件(event),之间进行协调,在时间上出现一致 ...