[atARC063F]Snuke's Coloring 2
首先,可以通过将所有$x_{i}=0$都选择第1类,其余选第2类,构造出一个以$(0,0)$和$(1,h)$为左下角和右上角的矩形,答案即为$2h+2$,类似地还可以构造出$2w+2$
若最终的矩形不包含与$x=\frac{w}{2}$或$y=\frac{h}{2}$,那么意味着答案不超过$w+h$,而上面的构造得到了答案$2\max(w,h)+2$的下限,因此一定不优
接下来,我们分别考虑与$x=\frac{w}{2}$有交和与$y=\frac{h}{2}$有交的答案,取max即可
以$y=\frac{h}{2}$为例,暴力枚举右端点的$x$(记作$x_{i}$),即找到$j$,并最大化$x_{i}-x_{j}+\Delta y_{j+1,i-1}$(其中$\Delta y_{i,j}$指对应的最小的$y$坐标差,即$\min_{i\le k\le j,y_{k}>\frac{h}{2}}y_{k}-\max_{i\le k\le j,y_{k}\le \frac{h}{2}}y_{k}$)
(关于$\Delta y_{i,j}$中若存在$i\le k\le j$且$y_{k}=\frac{h}{2}$,看上去会有两种可能,但一定不优,任取即可)
$x_{i}$是关于$i$的常数,即要求最大化$\Delta y_{j+1,i-1}-x_{j}$,注意到每一次增加$i$也就是对$\Delta y_{j+1,i-1}$执行区间修改,修改的区间个数恰好与单调栈弹出数相同,用线段树来维护$\Delta y_{j+1,i-1}-x_{j}$最大值即可

1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 300005
4 #define oo 0x3f3f3f3f
5 #define L (k<<1)
6 #define R (L+1)
7 #define mid (l+r>>1)
8 #define fi first
9 #define se second
10 stack<int>st[2];
11 pair<int,int>a[N];
12 int n,w,h,ans,f[N<<2],tag[N<<2];
13 void upd(int k,int x){
14 tag[k]+=x;
15 f[k]+=x;
16 }
17 void down(int k){
18 upd(L,tag[k]);
19 upd(R,tag[k]);
20 tag[k]=0;
21 }
22 void update(int k,int l,int r,int x,int y,int z){
23 if ((l>y)||(x>r))return;
24 if ((x<=l)&&(r<=y)){
25 upd(k,z);
26 return;
27 }
28 down(k);
29 update(L,l,mid,x,y,z);
30 update(R,mid+1,r,x,y,z);
31 f[k]=max(f[L],f[R]);
32 }
33 void calc(){
34 sort(a+1,a+n+1);
35 while (!st[0].empty())st[0].pop();
36 st[0].push(0);
37 while (!st[1].empty())st[1].pop();
38 st[1].push(0);
39 memset(tag,0,sizeof(tag));
40 memset(f,0,sizeof(f));
41 upd(1,-oo);
42 int hh=h/2;
43 for(int i=1;i<=n;i++){
44 update(1,1,n,i,i,oo+h-a[i-1].fi);
45 ans=max(ans,a[i].fi+f[1]);
46 int p=(a[i].se>hh),las=i,x=abs(a[i].se-hh)-abs(p*h-hh);
47 while (1){
48 update(1,1,n,st[p].top()+1,las,x);
49 las=st[p].top();
50 x=abs(a[i].se-hh)-abs(a[las].se-hh);
51 if ((!las)||(x>0))break;
52 st[p].pop();
53 }
54 st[p].push(i);
55 }
56 ans=max(ans,w+max(f[1],h-a[n].fi));
57 }
58 int main(){
59 scanf("%d%d%d",&w,&h,&n);
60 for(int i=1;i<=n;i++)scanf("%d%d",&a[i].fi,&a[i].se);
61 calc();
62 swap(w,h);
63 for(int i=1;i<=n;i++)swap(a[i].fi,a[i].se);
64 calc();
65 printf("%d",2*ans);
66 }
[atARC063F]Snuke's Coloring 2的更多相关文章
- [Arc063F] Snuke's Coloring 2
[Arc063F] Snuke's Coloring 2 题目大意 给你一个网格图,一些点上有标记,求边长最大空白矩形. 试题分析 专门卡\(\log^2 n\)系列. 首先由题意我们可以找到答案的下 ...
- 【ARC 063F】Snuke's Coloring 2
Description There is a rectangle in the xy-plane, with its lower left corner at (0,0) and its upper ...
- すぬけ君の塗り絵 / Snuke's Coloring AtCoder - 2068 (思维,排序,贡献)
Problem Statement We have a grid with H rows and W columns. At first, all cells were painted white. ...
- Snuke's Coloring 2-1
There is a rectangle in the xy-plane, with its lower left corner at (0,0) and its upper right corner ...
- AtCoder Regular Contest 063 F : Snuke’s Coloring 2 (线段树 + 单调栈)
题意 小 \(\mathrm{C}\) 很喜欢二维染色问题,这天他拿来了一个 \(w × h\) 的二维平面 , 初始时均为白色 . 然后他在上面设置了 \(n\) 个关键点 \((X_i , Y_i ...
- 2018.09.22 atcoder Snuke's Coloring 2(线段树+单调栈)
传送门 就是给出一个矩形,上面有一些点,让你找出一个周长最大的矩形,满足没有一个点在矩形中. 这个题很有意思. 考虑到答案一定会穿过中线. 于是我们可以把点分到中线两边. 先想想暴力如何解决. 显然就 ...
- 2018.09.19 atcoder Snuke's Coloring(思维题)
传送门 谁能想到这道题会写这么久. 本来是一道很sb的题啊. 就是每次选一个点只会影响到周围的九个方格,随便1e9进制就可以hash了,但是我非要作死用stl写. 结果由于技术不够高超,一直调不出来. ...
- [arc063F]Snuke's Coloring 2-[线段树+观察]
Description 传送门 Solution 我们先不考虑周长,只考虑长和宽. 依题意得答案下限为max(w+1,h+1),并且最后所得一定是个矩形(矩形内部无点). 好的,所以!!!答案一定会经 ...
- ARC063F すぬけ君の塗り絵 2 / Snuke's Coloring 2
题面 一句话题面:给你一些点,求这些点之中夹的最大的矩形周长.(考虑边界) Solution 首先是一个结论,答案矩形一定经过\(x=\frac{w}{2}\)或经过\(y=\frac{h}{2}\) ...
随机推荐
- NX CAM 区域轮廓铣的切削步长
从NX3.0到NX9.0,默认都是5%.可是实际计算的精确度是不一样的.到NX8.0上发现计算速度特别慢,后来东找西找,设置这个参数可以解决.PS:请慎用!请后后面的官方解释. 官方的解释是: &qu ...
- Java中的函数式编程(三)lambda表达式
写在前面 lambda表达式是一个匿名函数.在Java 8中,它和函数式接口一起,共同构建了函数式编程的框架. lambda表达式乍看像是匿名内部类的一种语法糖,但实际上,它们是两种本质不同的事物 ...
- [Git系列] 前言
Git 简介 Git 是一个重视速度的分布式版本控制和代码管理系统,最初是由 Linus Torvalds 为开发 Linux 内核而设计并开发的,是一款遵循二代 GUN 协议的免费软件.这一教程会向 ...
- BUAA_2020_软件工程_结对项目作业
项目 内容 这个作业属于哪个课程 班级博客 这个作业的要求在哪里 作业要求 我在这个课程的目标是 掌握软件工程的思路方法 这个作业在哪个具体方面帮助我实现目标 学习结对编程 教学班级 006 项目地址 ...
- 网络摄像机中的IR-CUT详解
自然界存在着各种波长的光线,通过折射人眼能看到不同颜色的光线,这就是光线的波长不同所导致的.其实还有许多光线是人眼看不到的,人眼识别光线的波长范围在320nm-760nm之间,超过760nm的光线人眼 ...
- 《基于SIR的路边违停行为传播模型研究》
My Focus: 路边违停 行为的传播模型; 学习基于SIR XXX模型的可行性分析.建立和结论分析 Author: 左忠义,王英英,包蕴 Mind Map:
- Asp.Net mvc4 +Spring
添加相应的引用对象.(以下全部) 修改mvc的Global.asax文件内容 需要将控制器中原来需要new出来的对象改成属性成员 添加这个属性的注入对象 再去修改spring对web.config的一 ...
- C++实现红黑树
红黑树的应用: 利用key_value对,快速查找,O(logn) socket与客户端id之间,形成映射关系(socket, id) 内存分配管理 一整块内存,不断分配小块 每分配一次,就加入到红黑 ...
- Springboot第一次访问慢,自身缺陷问题?
一.现象: 1.访问controller,第一次速度在300-400ms,第二次访问就很快了大概在20ms,相差几十倍,是哪里出了问题,尝试了网上很多教程都没有作用 如启动参数设置 -Djava.se ...
- ASP的调试技术解答
一. 调试 ASP.NET 应用程序时出现"未将项目配置为进行调试"的错误信息 症状 当您在 Visual Studio .NET 中调试 ASP.NET 应用程序时,可能会出现下 ...