本题解提供的做法思路应该是比较清晰的,可惜代码实现比较繁琐,仅供大家参考。

题解

不难发现 \(x\) ,\(y\) 的取值范围只有 \(200\) ,所以我们可以考虑从这里入手。我们可以先通过二维前缀和将每个点的上色次数算出来,然后考虑再画矩形。

我们可以先考虑一个矩形的情况,不难发现,如果矩形内的每有一个 \(k-1\) 可以使答案加一,每有一个 \(k\) 可以使答案减一。那如果我们要使答案最大,肯定是 \(1\) 与 \(-1\) 的最大的一个矩阵,发现就是做一个最大矩阵和,可以 \(O(200^3)\) 去搞。

我们再来考虑两个矩形的情况,不难发现,如果是两个边与 \(x\) 轴和 \(y\) 轴平行的不相交的矩形,我们肯定可以用一条平行与 \(x\) 轴或 \(y\) 轴的直线将其分开。如图:



所以我们只需要将整个平面通过平行于 \(x\) 轴和 \(y\) 轴的直线分成两部分,再在其中做最大矩阵和就可以了。

当然直接做是肯定会炸的,所以你需要进行一堆的预处理和前缀和,仔细一点就好了。

以上。

代码如下:

#include<bits/stdc++.h>
using namespace std;
const int N=1e5+5,M=205,K=1e5+5;
int n,m=200,k;
int h[M][M],res=0,ans=0;
int cntx[M][M],cnty[M][M];
int ansx[M][M],ansy[M][M];
int hhhx[2][M],hhhy[2][M];
int main()
{
cin>>n>>k;
for(int i=1,x1,y1,x2,y2;i<=n;++i)
{
scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
++x1,++y1,++x2,++y2;
h[x1][y1]++,h[x2][y2]++;
h[x1][y2]--,h[x2][y1]--;
}
for(int i=1;i<=m;++i)
{
for(int j=1;j<=m;++j)
h[i][j]+=h[i-1][j]+h[i][j-1]-h[i-1][j-1],res+=(h[i][j]==k);
}
// for(int i=1;i<=8;++i)
// {
// for(int j=1;j<=8;++j)
// printf("%d ",h[i][j]);
// printf("\n");
// }
// printf("\n");
for(int i=1;i<=m;++i)
{
for(int j=1;j<=m;++j)
{
cntx[i][j]=cntx[i-1][j]+(h[i][j]==k-1)-(h[i][j]==k);
cnty[i][j]=cnty[i][j-1]+(h[i][j]==k-1)-(h[i][j]==k);
}
}
// for(int i=1;i<=8;++i)
// {
// for(int j=1;j<=8;++j)
// printf("%d ",cntx[i][j]);
// printf("\n");
// }
// printf("\n");
// for(int i=1;i<=8;++i)
// {
// for(int j=1;j<=8;++j)
// printf("%d ",cnty[i][j]);
// printf("\n");
// }
// printf("\n");
int tmp;
for(int i=1;i<=m;++i)
{
for(int j=1;j<=i;++j)
{
tmp=0;
for(int c=1;c<=m;++c)
{
tmp=max(tmp+cntx[i][c]-cntx[j-1][c],0);
ansx[i][j]=max(ansx[i][j],tmp);
}
}
}
for(int i=1;i<=m;++i)
{
for(int j=1;j<=i;++j)
{
tmp=0;
for(int c=1;c<=m;++c)
{
tmp=max(tmp+cnty[c][i]-cnty[c][j-1],0);
ansy[i][j]=max(ansy[i][j],tmp);
}
}
}
// for(int i=1;i<=8;++i)
// {
// for(int j=1;j<=8;++j)
// printf("%d ",ansx[i][j]);
// printf("\n");
// }
// printf("\n");
// for(int i=1;i<=8;++i)
// {
// for(int j=1;j<=8;++j)
// printf("%d ",ansy[i][j]);
// printf("\n");
// }
// printf("\n");
for(int i=1;i<=m;++i)
{
hhhx[0][i]=hhhx[0][i-1];
for(int j=1;j<=i;++j)
hhhx[0][i]=max(hhhx[0][i],ansx[i][j]);
}
for(int i=m;i>=1;--i)
{
hhhx[1][i]=hhhx[1][i+1];
for(int j=m;j>=i;--j)
hhhx[1][i]=max(hhhx[1][i],ansx[j][i]);
}
for(int i=1;i<=m;++i)
{
hhhy[0][i]=hhhy[0][i-1];
for(int j=1;j<=i;++j)
hhhy[0][i]=max(hhhy[0][i],ansy[i][j]);
}
for(int i=m;i>=1;--i)
{
hhhy[1][i]=hhhy[1][i+1];
for(int j=m;j>=i;--j)
hhhy[1][i]=max(hhhy[1][i],ansy[j][i]);
}
ans=res;
for(int i=2;i<=m;++i) ans=max(ans,res+hhhx[0][i-1]+hhhx[1][i]);
for(int i=2;i<=m;++i) ans=max(ans,res+hhhy[0][i-1]+hhhy[1][i]);
printf("%d\n",ans);
return 0;
}

P6100 [USACO19FEB]Painting the Barn G的更多相关文章

  1. [USACO19FEB]Painting the Barn G

    题意 \(n\)个矩阵\((0\le x_1,y_1,x_2,y_2\le 200)\),可交,可以再放最多两个矩阵(这两个矩阵彼此不交),使得恰好被覆盖\(k\)次的位置最大.\(n,k\le 10 ...

  2. 洛谷 P5542 [USACO19FEB]Painting The Barn

    题目传送门 解题思路: 二维差分的板子题.题解传送门 AC代码: #include<iostream> #include<cstdio> using namespace std ...

  3. java成神之——ImmutableClass,null检查,字符编码,defaultLogger,可变参数,JavaScriptEngine,2D图,类单例,克隆,修饰符基本操作

    ImmutableClass null检查 字符编码 default logger 函数可变参数 Nashorn JavaScript engine 执行脚本文件 改变js文件输出流 全局变量 2D图 ...

  4. Storyboards Tutorial 03

    这一节主要介绍segues,static table view cells 和 Add Player screen 以及 a game picker screen. Introducing Segue ...

  5. 文件图标SVG

    ​<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink ...

  6. [USACO17DEC] Barn Painting

    题目描述 Farmer John has a large farm with NN barns (1 \le N \le 10^51≤N≤105 ), some of which are alread ...

  7. [USACO17DEC] Barn Painting - 树形dp

    设\(f[i][j]\)为\(i\)子树,当\(i\)为\(j\)时的方案数 #include <bits/stdc++.h> using namespace std; #define i ...

  8. 树链剖分详解&题解 P6098 【[USACO19FEB]Cow Land G】

    看到各位大佬们已经把其他的东西讲的很明白了,我这个 juruo 就讲一讲最基本的树链剖分吧. 0.树剖是什么?能吃吗? 不能吃 树剖是树链剖分的简称,我们一般说的树剖其实指重链剖分.当然,还有一种长链 ...

  9. [USACO 2017DEC] Barn Painting

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=5141 [算法] 树形DP 时间复杂度 : O(N) [代码] #include< ...

随机推荐

  1. 爬虫练习之正则表达式爬取猫眼电影Top100

    #猫眼电影Top100import requests,re,timedef get_one_page(url): headers={ 'User-Agent':'Mozilla/5.0 (Window ...

  2. intelx86为何从0xFFFF0处执行

    第一条指令的地址 在用户按下计算机电源开关之后,CPU会自动的将其CS寄存器设定为0xFFFF,将其IP寄存器设定为0x0000.由于CS:IP指出了下一条指令的地址[1],因此CPU会跳到0xFFF ...

  3. 阿里巴巴已offer:Java实习五面详细面经(附解答)

    1.岗位 Java后台开发实习生 2.时间表 2020/3/18 提交简历 & 测评 2020/3/23 笔试 2020/3/26 简历面 2020/4/11 技术一面 2020/4/14 技 ...

  4. window.frames["id"].location使用

    由于最近需要维护一个老项目不得不去学习一些自己都没接触过的项目,老项目中虽然技术已经被淘汰,但是思想还是值得去学习探究的,无论是jsp,freemarker,freemarker这些模板引擎还是Vue ...

  5. java大厂面经-阿里腾讯、网易美团、京东、华为、快手、字节全在这里了

    前言 在这篇文章详细说了该如何去复习,之前也答应各位把面经整理一下,但是因为入职的事情耽搁了,现在整理出来回馈给大家! 美团 一面 0.自我介绍1.问项目(项目详细介绍.用到什么技术.有什么优化)2. ...

  6. pdfFactory如何设置限制打印和浏览文档权限

    当我们进行私密文件的分享时,除了要设置密码保护文件内容外,还要注意设置打印限制,防止他人利用打印的方式,进行纸质文件的传播. 在使用pdfFactory安全策略时,我们可以通过设定禁止打印的方式,完全 ...

  7. 下载器Folx怎么安装使用

    应该使用哪个下载工具?这个如果是Windows上会有无数答案的问题,在Mac上却变得异常的纠结.比如Leech和Aria2,这两款软件,前者功能相对比较简单,后者的配置又稍微有点复杂,很难找到一款相对 ...

  8. 如何用MathType 7输入x的一阶导数

    物理学.几何学.经济学等学科中的一些重要概念都可以用导数来表示.如,导数可以表示运动物体的瞬时速度和加速度.可以表示曲线在一点的斜率.还可以表示经济学中的边际和弹性.那么作为专业的公式编辑器,如何输入 ...

  9. recovery.sh

    #!/bin/bash source /etc/profile Time=`date +%F-%H-%M` Dir=/data/any.service.recovery if [ ! -d $Dir ...

  10. SpringCloud 源码系列(1)—— 注册中心 Eureka(上)

    Eureka 是 Netflix 公司开源的一个服务注册与发现的组件,和其他 Netflix 公司的服务组件(例如负载均衡.熔断器.网关等)一起,被 Spring Cloud 整合为 Spring C ...