最大子矩阵...悬线法..时间复杂度O(nm)

悬线法就是记录一个H向上延伸的最大长度(悬线), L, R向左向右延伸的最大长度, 然后通过递推来得到.

------------------------------------------------------------------

#include<bits/stdc++.h>
using namespace std;
#define ok(c) ((c) == 'F' || (c) == 'R')
const int maxn = 1009;
int H[maxn][maxn], L[maxn][maxn], R[maxn][maxn], N, M;
bool F[maxn][maxn];
void Read() {
cin >> N >> M;
for(int i = 0; i < N; i++)
   for(int j = 0; j < M; j++) {
char c = getchar();
for(; !ok(c); c = getchar());
F[i][j] = c == 'F';
   }
}
int main() {
Read();
for(int i = 0; i < N; i++) {
L[i][0] = F[i][0];
for(int j = 1; j < M; j++)
   L[i][j] = F[i][j] ? L[i][j - 1] + 1 : 0;
R[i][M - 1] = F[i][M - 1];
for(int j = M - 2; ~j; j--)
   R[i][j] = F[i][j] ? R[i][j + 1] + 1 : 0;
}
memset(H, 0, sizeof H);
for(int i = 1; i < N; i++)
for(int j = 0; j < M; j++) if(F[i][j] && F[i - 1][j]) {
   H[i][j] = H[i - 1][j] + 1;
   L[i][j] = min(L[i][j], L[i - 1][j]);
   R[i][j] = min(R[i][j], R[i - 1][j]);
}
int ans = 0;
for(int i = 0; i < N; i++)
   for(int j = 0; j < M; j++) if(F[i][j])
       ans = max(ans, (H[i][j] + 1) * (L[i][j] + R[i][j] - 1));
cout << 3 * ans << "\n";
return 0;
}

------------------------------------------------------------------

3039: 玉蟾宫

Time Limit: 2 Sec  Memory Limit: 128 MB
Submit: 581  Solved: 352
[Submit][Status][Discuss]

Description

有一天,小猫rainbow和freda来到了湘西张家界的天门山玉蟾宫,玉蟾宫宫主蓝兔盛情地款待了它们,并赐予它们一片土地。
这片土地被分成N*M个格子,每个格子里写着'R'或者'F',R代表这块土地被赐予了rainbow,F代表这块土地被赐予了freda。
现在freda要在这里卖萌。。。它要找一块矩形土地,要求这片土地都标着'F'并且面积最大。
但是rainbow和freda的OI水平都弱爆了,找不出这块土地,而蓝兔也想看freda卖萌(她显然是不会编程的……),所以它们决定,如果你找到的土地面积为S,它们每人给你S两银子。

Input

第一行两个整数N,M,表示矩形土地有N行M列。
接下来N行,每行M个用空格隔开的字符'F'或'R',描述了矩形土地。

Output

输出一个整数,表示你能得到多少银子,即(3*最大'F'矩形土地面积)的值。

Sample Input

5 6
R F F F F F
F F F F F F
R R R F F F
F F F F F F
F F F F F F

Sample Output

45

HINT

对于50%的数据,1<=N,M<=200

对于100%的数据,1<=N,M<=1000

Source

Poetize4

转载于:https://www.cnblogs.com/JSZX11556/p/4715241.html

BZOJ 3039: 玉蟾宫( 悬线法 )相关推荐

  1. BZOJ[3039]玉蟾宫 悬线法

    题目链接http://www.lydsy.com/JudgeOnline/problem.php?id=3039 Description 有一天,小猫rainbow和freda来到了湘西张家界的天门山 ...

  2. [P4147 玉蟾宫(悬线法)

    题目链接: P4147 玉蟾宫 题目大意: n ∗ m n∗m n∗m的矩阵,求最大的全 F F F矩阵面积 ∗ 3 *3 ∗3. 思路:悬线法. 参考代码: #include <bits/st ...

  3. bzoj 3039: 玉蟾宫(悬线法)

    3039: 玉蟾宫 Time Limit: 2 Sec  Memory Limit: 128 MB Submit: 975  Solved: 562 [Submit][Status][Discuss] ...

  4. BZOJ 3039 玉蟾宫 最大子矩阵 算♂法②

    题意:链接 方法:最大子矩阵之算♂法② 解析: 首先这道题单调栈DP是肯定能过的,但是一点都不高端! 什么年代了还用这种方式! 所以如何彰显自己是个高端的人呢? 悬线法能满足你的需求! 什么是悬线法? ...

  5. BZOJ 3039: 玉蟾宫

    3039: 玉蟾宫 Description 有一天,小猫rainbow和freda来到了湘西张家界的天门山玉蟾宫,玉蟾宫宫主蓝兔盛情地款待了它们,并赐予它们一片土地. 这片土地被分成N*M个格子,每个 ...

  6. BZOJ 3039 玉蟾宫

    Description 有一天,小猫rainbow和freda来到了湘西张家界的天门山玉蟾宫,玉蟾宫宫主蓝兔盛情地款待了它们,并赐予它们一片土地. 这片土地被分成N*M个格子,每个格子里写着'R'或者 ...

  7. bzoj 3039 玉蟾宫 单调栈

    预处理出每个点向上扩展的高度,对于每一行维护单调递增的栈,在弹出元素的时候统计答案. #include<iostream> #include<cstdio> #include& ...

  8. 【BZOJ-30391057】玉蟾宫棋盘制作 悬线法

    3039: 玉蟾宫 Time Limit: 2 Sec  Memory Limit: 128 MB Submit: 753  Solved: 444 [Submit][Status][Discuss] ...

  9. 洛谷 P4147 玉蟾宫【悬线法/单调栈】

    题目背景 有一天,小猫 rainbow 和 freda 来到了湘西张家界的天门山玉蟾宫,玉蟾宫宫主蓝兔盛情地款待了它们,并赐予它们一片土地. 题目描述 这片土地被分成 N×MN\times MN×M ...

最新文章

  1. 在Ubuntu 16.04.3 LTS上运行go install出错的问题
  2. boost::type_index::ctti_type_index相关的测试程序
  3. java对mysql数据库进行单表筛选备份、还原操作
  4. linux c 文件映射,linuxc试题
  5. 巩膜(眼白)灰色原因
  6. 我在工作中是如何使用Git的
  7. python之os、sys和random模块
  8. 请领导批阅文件怎么说_请领导吃饭,不要对外说,职场员工为何如此保密?
  9. 数组c语言与指针,浅析C语言数组与指针
  10. 20万DBA都在关注的12个问题
  11. batch入门教程(4)
  12. wemall app商城源码Android中ViewHolder详细解释
  13. linux 定位 踩内存_运维常见问题故障定位,这里总结全了!
  14. 使用layUI弹出输入框并收集输入框信息
  15. Reservior Sampling (蓄水池抽样算法)
  16. DevOps系列之 —— 持续规划与设计(三)敏捷项目管理的方法【Kanban 与 Scrum】
  17. 付费?不存在的,20 行代码将电子书转换为有声小说
  18. 6.1_[Java 数组]-数组与二重循环和鸡兔同笼及冒泡排序
  19. Android应用开发之RelativeLayout (相对布局)+梅花效果案例
  20. 人人都是产品经理之用Axure制作微信主页原型图

热门文章

  1. 【图像超分辨率】基于ResNet或GAN的遥感图像超分辨率论文
  2. 计算机控制技术与自动化的关系,计算机控制技术东南大学自动化学院.ppt
  3. CF思维联系– Codeforces-987C - Three displays ( 动态规划)
  4. FZU 1894 志愿者选拔
  5. cpu和内存之间——地址映射
  6. 深入浅出深度学习(二)分类器
  7. 文本文件加密和解密_解密文本见解和相关业务用例
  8. C语言高级编程:const限定函数形参
  9. 安卓PopupWindow
  10. python亲和度_数据挖掘——亲和性分析