Largest Submatrix 3 CodeForces - 407D (dp,好题)
大意: 给定矩阵, 求选出一个最大矩形, 满足矩形内每个元素互不相同.
考虑枚举上下左三个边界, 求出最大右边界的位置.
注意到固定上边界, 下边界递推时, 每个左边界对应最大右边界是单调不增的.
所以只需考虑下边界所在行的影响, 与之前的取最小即可.
用$set$求的话复杂度是$O(n^3logn)$, 没有卡过去.
$set$改成$vEB$树的话复杂度可以达到$O(n^3loglogn)$, 或许可以过.
实际上可以发现, 下边界所在行每个点的最大右边界在上边界递减时是非增的, 可以倒序枚举上边界, 这样就可以达到复杂度$O(n^3)$.
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <string.h>
#define REP(i,a,n) for(int i=a;i<=n;++i)
#define PER(i,a,n) for(int i=n;i>=a;--i)
using namespace std; const int N = 410;
int n, m, a[N][N], R[N][N];
int l1[N], r1[N], vis[N*N]; int main() {
scanf("%d%d", &n, &m);
REP(i,1,n) REP(j,1,m) scanf("%d",a[i]+j);
memset(R,0x3f,sizeof R);
int ans = 0;
REP(D,1,n) {
REP(i,1,m) r1[i]=m+1,l1[i]=0;
//l1[i] 是行范围在[U,D]内, 列在i左侧, 存在与a[D][i]相等的最接近i的列数
//r1[i] 是行范围在[U,D]内, 列在i右侧, 存在与a[D][i]相等的最接近i的列数
//R[U][i] 为上边界U, 下边界D, 左边界i的矩形的最大右边界
PER(U,1,D) {
int now = 1;
REP(i,1,m) {
now = max(now, i);
while (now<r1[i]&&!vis[a[U][now]]&&!vis[a[D][now]]) {
if (U!=D&&a[U][now]==a[D][now]) break;
vis[a[U][now]] = vis[a[D][now]] = 1;
++now;
}
vis[a[U][i]] = vis[a[D][i]] = 0;
r1[i] = min(r1[i], now);
}
now = m;
PER(i,1,m) {
now = min(now, i);
while (now>l1[i]&&!vis[a[U][now]]&&!vis[a[D][now]]) {
if (U!=D&&a[U][now]==a[D][now]) break;
vis[a[U][now]] = vis[a[D][now]] = 1;
--now;
}
vis[a[U][i]] = vis[a[D][i]] = 0;
l1[i] = max(l1[i], now);
}
REP(i,1,m) {
R[U][i] = min(R[U][i],r1[i]-1);
R[U][l1[i]] = min(R[U][l1[i]],i-1);
}
PER(i,1,m) {
R[U][i] = min(R[U][i], R[U][i+1]);
ans = max(ans, (D-U+1)*(R[U][i]-i+1));
}
}
}
printf("%d\n", ans);
}
还有一种编码非常简单的区间$DP$做法.
设$f_{i,l,r}$为下边界$i$,左右边界$l,r$的最小上边界值, 有转移
$f_{i,l,r}=max\{f_{i-1,l,r},f_{i,l+1,r},f_{i,l,r-1},a_{i,l}$与$a_{1..i,r}$的限制$,a_{1..i,l}$与$a_{i,r}$的限制$\}$
#include <iostream>
#include <algorithm>
#include <cstdio>
#define REP(i,a,n) for(int i=a;i<=n;++i)
using namespace std; const int N = 402;
int n,m,a[N][N],f[N][N],pre[N][N*N]; int main() {
scanf("%d%d", &n, &m);
REP(i,1,n) REP(j,1,m) scanf("%d",a[i]+j);
int ans = 0;
REP(i,1,n) REP(d,1,m) {
for (int l=1,r=d; r<=m; ++l,++r) {
if (l==r) f[l][l]=max(f[l][l],pre[l][a[i][l]]);
else if (a[i][l]==a[i][r]) f[l][r] = i;
else {
f[l][r]=max({f[l][r],f[l][r-1],f[l+1][r],pre[r][a[i][l]],pre[l][a[i][r]]});
}
ans = max(ans, (i-f[l][r])*(r-l+1));
}
REP(j,1,m) pre[j][a[i][j]]=i;
}
printf("%d\n", ans);
}
Largest Submatrix 3 CodeForces - 407D (dp,好题)的更多相关文章
- Array Beauty CodeForces - 1189F (dp,好题)
大意: 定义$n$元素序列$a$的美丽度为 $\min\limits_{1\le i<j\le n}|a_i-a_j|$. 给定序列$a$, 求$a$的所有长为$k$的子序列的美丽度之和. 记 ...
- DP刷题记录
目录 dp刷题记录 codeforces 706C codeforces 940E BZOJ3997 POJ2279 GYM102082B GYM102082D codeforces132C L3-0 ...
- codeforces 407D Largest Submatrix 3
codeforces 407D Largest Submatrix 3 题意 找出最大子矩阵,须满足矩阵内的元素互不相等. 题解 官方做法 http://codeforces.com/blog/ent ...
- Codeforces 148D 一袋老鼠 Bag of mice | 概率DP 水题
除非特别忙,我接下来会尽可能翻译我做的每道CF题的题面! Codeforces 148D 一袋老鼠 Bag of mice | 概率DP 水题 题面 胡小兔和司公子都认为对方是垃圾. 为了决出谁才是垃 ...
- Largest Submatrix(动态规划)
Largest Submatrix Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...
- POJ-3494 Largest Submatrix of All 1’s (单调栈)
Largest Submatrix of All 1’s Time Limit: 5000MS Memory Limit: 131072K Total Submissions: 8551 Ac ...
- hdu 2870 Largest Submatrix(平面直方图的最大面积 变形)
Problem Description Now here is a matrix with letter 'a','b','c','w','x','y','z' and you can change ...
- [POJ2559&POJ3494] Largest Rectangle in a Histogram&Largest Submatrix of All 1’s 「单调栈」
Largest Rectangle in a Histogram http://poj.org/problem?id=2559 题意:给出若干宽度相同的矩形的高度(条形统计图),求最大子矩形面积 解题 ...
- poj 2955 Brackets (区间dp基础题)
We give the following inductive definition of a “regular brackets” sequence: the empty sequence is a ...
随机推荐
- 【零基础】神经网络优化之L1、L2
一.序言 前面的文章中,我们逐步从单神经元.浅层网络到深层网络,并且大概搞懂了“向前传播”和“反向传播”的原理,比较而言深层网络做“手写数字”识别已经游刃有余了,但神经网络还存在很多问题,比如最常见的 ...
- 【Oracle/Maven】Maven导入oracle11g 自携带jdbc驱动包ojdbc6.jar到本地库
Maven需要下载解压并添加到classpath,如果不明可以参考https://www.cnblogs.com/xiandedanteng/p/11403480.html 然后在命令行窗口执行: m ...
- 原创 linux 爬虫拨号服务器完整设置
[root@cloud ~]# cat /home/bh.sh #!/bin/bash PATH=/sbin:/bin:/usr/sbin:/usr/bin:/sbin/ifconfig /usr/s ...
- PorterDuffXfermode之PorterDuff.Mode.LIGHTEN
package com.loaderman.customviewdemo.view; import android.content.Context; import android.graphics.B ...
- 一个Flask应用运行过程剖析
相信很多初学Flask的同学(包括我自己),在阅读官方文档或者Flask的学习资料时,对于它的认识是从以下的一段代码开始的: from flask import Flask app = Flask(_ ...
- Springboot整合Elasticsearch报错availableProcessors is already set to [4], rejecting [4]
Springboot整合Elasticsearch报错 今天使用SpringBoot整合Elasticsearch时候,相关的配置完成后,启动项目就报错了. nested exception is j ...
- CentOS7下配置Tomcat以APR模式+Tomcat Native运行
在慢速网络上Tomcat线程数开到300以上的水平,不配APR,基本上300个线程狠快就会用满,以后的请求就只好等待.但是配上APR之后,Tomcat将以JNI的形式调用Apache HTTP服务器的 ...
- python中简化的验证码功能
验证码一般用来验证登陆.交易等行为,减少对端为机器操作的概率,python中可以使用random模块,char()内置函数来实现一个简单的验证码功能. import random def veri_c ...
- PAT 甲级 1060 Are They Equal (25 分)(科学计数法,接连做了2天,考虑要全面,坑点多,真麻烦)
1060 Are They Equal (25 分) If a machine can save only 3 significant digits, the float numbers 1230 ...
- 利用python批量修改word文件名的方法示例
利用python批量修改word文件名的方法示例 最近不小心把硬盘给格式化了,由于当时的文件没有备份,所以一下所有的文件都没有了,于是只能采取补救措施,用文件恢复软件恢复了一部分的数据出来,但是恢复完 ...