《AT_arc081_d [ARC081F] Flip and Rectangles》

题目描述

有一个 H×W 的网格。网格中的每个格子被涂成黑色或白色。从上到下第 i 行,从左到右第 j 列的格子,如果 Si​ 的第 j 个字符是 #,那么该格子是黑色;如果是 .,那么是白色。

Sunnuke 君可以任意次数地进行如下操作:

  • 任选网格中的某一行或某一列,将该行或该列的所有格子的颜色反转(即,将黑色格子变成白色,将白色格子变成黑色)。

在操作结束后,Sunnuke 君会选择网格中的一个长方形。此时,所选长方形中的所有格子必须都是黑色。

若操作合理,Sunnuke 君能选择的长方形的最大面积是多少?

输入格式

输入以如下格式从标准输入中给出。

H W

S1​

S2​

SH​

输出格式

输出 Sunnuke 君能选择的最大长方形的面积。

显示翻译

题意翻译

输入输出样例

输入 #1复制

复制代码
3 3
..#
##.
.#.

输出 #1复制

复制代码
6

输入 #2复制

复制代码
4 4
....
....
....
....

输出 #2复制

复制代码
16

输入 #3复制

复制代码
10 8
##...#.#
##...#.#
..###.#.
#.##.#.#
.#..#.#.
..##.#.#
##.#.#..
...#.#..
###.#.##
###..###

输出 #3复制

复制代码
27

说明/提示

限制条件

  • 2≤H≤2000
  • 2≤W≤2000
  • ∣Si∣=W
  • Si 仅由 #. 组成。

样例说明 1

如图所示,如果将第 1 行和第 3 列进行反转,则可以选出一个 2×3 的长方形。

由 ChatGPT 5 翻译

代码实现:

cpp 复制代码
#include "iostream"
#include "cstdio"

#define N 2005

using namespace std;

int n,m,ans;
int L[N][N],R[N][N],h[N][N];
bool g[N][N];

int main()
{
    scanf("%d%d",&n,&m);
    ans=max(n,m);
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            char c;
            cin>>c;
            if(c=='#')
                g[i][j]=true;
        }
    }
    n--;m--;
    for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)
        {
            g[i][j]=!((g[i][j]+g[i+1][j]+g[i][j+1]+g[i+1][j+1])&1);
            L[i][j]=R[i][j]=j;
        }
    for(int i=1;i<=n;i++)
        for(int j=2;j<=m;j++)
            if(g[i][j]&&g[i][j-1])
                L[i][j]=L[i][j-1];
    for(int i=1;i<=n;i++)
        for(int j=m-1;j;j--)
            if(g[i][j]&&g[i][j+1])
                R[i][j]=R[i][j+1];
    for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)
            if(g[i][j])
                h[i][j]=h[i-1][j]+1;
    for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)
        {
            if(g[i][j]&&g[i-1][j])
            {
                L[i][j]=max(L[i][j],L[i-1][j]);
                R[i][j]=min(R[i][j],R[i-1][j]);
            }
            ans=max(ans,(R[i][j]-L[i][j]+2)*(h[i][j]+1));
        }
    printf("%d\n",ans);
    return 0;
}
相关推荐
Old Uncle Tom8 小时前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆8 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移8 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业8 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
智者知已应修善业11 小时前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
.54811 小时前
## Sorting(排序算法)
python·算法·排序算法
wuweijianlove12 小时前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归
子琦啊12 小时前
【算法复习】字符串 | 两个底层直觉,吃透高频题
linux·运维·算法
code_pgf13 小时前
Octo 算法详解-开源通用机器人策略模型技术报告
算法·机器人·开源
嘻嘻哈哈樱桃13 小时前
牛客经典101题题解集--动态规划
java·数据结构·python·算法·职场和发展·动态规划