题解-Happy New Year
题解-Happy New Year
给定 \(n\),\(m\) 和 \(k\)。有一个序列 \(a\{m\}\) 初始值为 \(0\)。有 \(n\) 种操作,每种可以使 \([L_i,R_i]\) 区间序列值 \(+1\)。每个操作最多用 \(1\) 次(可以不用)。保证对于每个 \(i(1\le i\le n)\) 最多存在 \(k\) 个不同的 \(j\) 满足 \(i\in[L_j,R_j]\)。求最后的序列中奇数最多个数。
数据范围:\(1\le n\le 10^5\),\(1\le m\le 10^9\),\(1\le k\le 8\)。
状压 \(\texttt{dp}\) 水题,连我这个小蒟蒻都几下就做出来了。
从数据范围和时间复杂度入手分析题目:
- 首先看到 \(n\) 的大小,就知道复杂度中要带个 \(n\)。
- 时间复杂度中不能带 \(m\),而且这题也不能二分倍增分治之类的,所以也不带 \(\log m\)。
- 时间复杂度可以带 \(k\),甚至还可以带个 \(2^k\)。考虑到这个 \(k\) 真是小到离奇,于是想着带 \(2^k\)——写个状压 \(\texttt{dp}\)。
将每个区间 \(i\) 的 \(L_i\) 和 \(R_i+1\) 带信息放进数组 \(p\) 中,按如下的 \(\texttt{cmp}\) 排序:
struct point{
int op,w,d; //如果是L_i,op=1,w=L_i;如果是R_i,op=-1,w=R_i+1。d=i
point(int OP=0,int W=0,int D=0){op=OP,w=W,d=D;}
};
int cmp(point x,point y){
if(x.w==y.w) return x.op<y.op; //※先处理R_i,防止中途当前覆盖区间数 >k
return x.w<y.w; //按大小排序
}
从左到右枚举每个端点,将当前覆盖着的区间放进数组 \(d\)。
令 \(f_{i,j}\) 表示到第 \(i\) 个端点,选择的区间覆盖状态为 \(j\) 的最大答案。
\(j\) 中二进制下如果第 \(at-1\) 位是 \(1\),则表示选择了区间 \(d_{at}\) 并且 \(d_{at}\) 正覆盖在当前端点上。
如果 \(at\) 表示该端点在数组 \(d\) 中的位置,那么相邻两个端点之间可以如下递推:
&\textbf{if}\ [p_i. op=1]:\\
&\qquad \textbf{if}\ [at\in j]:f_{i,j}=\max\{f_{i,j},f_{i-1,j}+[|j|\in \mathbb{odd}](p_i. w-p_{i-1}. w)\}\\
&\qquad \textbf{if}\ [at\notin j]:f_{i,j\cup\{at\}}=\max\{f_{i,j\cup\{at\}},f_{i-1,j}+[|j|\in \mathbb{odd}](p_i.w-1-p_{i-1}.w)+[(|j|+1)\in \mathbb{odd}]\}\\
&\textbf{if}\ [p_i. op=-1]:\\
&\qquad \textbf{if}\ [at\notin j]:\\
&\qquad \qquad f_{i,j}=\max\{f_{i,j},f_{i-1,j}+[|j|\in \mathbb{odd}](p_i.w-p_{i-1}.w)\}\\
&\qquad \qquad f_{i,j}=\max\{f_{i,j},f_{i-1,j\cup at}+[(|j|+1)\in \mathbb{odd}](p_i.w-1-p_{i-1}.w)\}+[|j|\in\mathbb{odd}]\}\\
\end{split}
\]
最后的答案就是 \(f_{2n,\varnothing}\)。
小蒟蒻怕自己讲不清楚,于是做了个动画:
Input
3 10 2
2 5
5 7
8 9

时间复杂度 \(\Theta(n2^k)\),空间复杂度 \(\Theta(n2^k)\)。
Code
蒟蒻的做法比较玄学,但是又很简单,所以放个代码走人吧。
#include <bits/stdc++.h>
using namespace std;
//Start
#define lng long long
#define db double
#define mk make_pair
#define pb push_back
#define fi first
#define se second
#define rz resize
const int inf=0x3f3f3f3f;
const lng INF=0x3f3f3f3f3f3f3f3f;
//Data
const int N=1e5,K=8;
int n,m,k;
int l[N+7],r[N+7];
struct point{
int op,w,d;
point(int OP=0,int W=0,int D=0){op=OP,w=W,d=D;}
};
int cmp(point x,point y){
if(x.w==y.w) return x.op<y.op;
return x.w<y.w;
}
int pcnt;
point p[(N<<1)+7];
//DP
int d[K+7],one[(1<<K)+7];
int f[(N<<1)+7][(1<<K)+7];
void Max(int&x,int y){x=max(x,y);}
int DP(){
int ful=(1<<k)-1;
for(int i=1;i<=ful;i++) one[i]=one[i-(i&-i)]+1;
for(int i=0;i<=pcnt;i++)
for(int j=0;j<=ful;j++) f[i][j]=-inf;
f[0][0]=0;
for(int j=1;j<=k;j++) d[j]=-1;
int now=0;
for(int i=1;i<=pcnt;i++){
int at=-1;
if(p[i].op==1){
for(int j=1;j<=k;j++)
if(d[j]==-1){at=j,d[j]=p[i].d;break;}
assert(~at);
for(int j=0;j<=now;j++)if((j&now)==j){
Max(f[i][j],f[i-1][j]+(one[j]&1)*(p[i].w-p[i-1].w));
Max(f[i][j|(1<<(at-1))],f[i-1][j]+(one[j]&1)*(p[i].w-1-p[i-1].w)+((one[j]+1)&1));
}
now|=(1<<(at-1));
} else {
for(int j=1;j<=k;j++)
if(d[j]==p[i].d){at=j,d[j]=-1;break;}
assert(~at);
now^=(1<<(at-1));
for(int j=0;j<=now;j++)if((j&now)==j){
Max(f[i][j],f[i-1][j]+(one[j]&1)*(p[i].w-p[i-1].w));
Max(f[i][j],f[i-1][j|(1<<(at-1))]+((one[j]+1)&1)*(p[i].w-1-p[i-1].w)+(one[j]&1));
}
}
}
return f[pcnt][0];
}
//Main
int main(){
scanf("%d%d%d",&n,&m,&k);
for(int i=1;i<=n;i++){
scanf("%d%d",&l[i],&r[i]);
p[++pcnt]=point(1,l[i],i);
p[++pcnt]=point(-1,r[i]+1,i);
}
sort(p+1,p+pcnt+1,cmp);
printf("%d\n",DP());
return 0;
}
祝大家学习愉快!
题解-Happy New Year的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
- JSOI2016R3 瞎BB题解
题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...
随机推荐
- mds的cpu占用问题分析以及解决办法
前言 mds是ceph里面处理文件接口的组件,一旦使用文件系统,不可避免的会出现一种场景就是目录很多,目录里面的文件很多,而mds是一个单进程的组件,现在虽然有了muti mds,但稳定的使用的大部分 ...
- Mac OS终端利器 iTem2 配置大全
转载链接:https://www.cnblogs.com/diyxiaoshitou/p/9017413.html 之前一直使用 Mac OS 自带的终端,用起来虽然有些不太方便,但总体来说还是可以接 ...
- java大厂面经-阿里腾讯、网易美团、京东、华为、快手、字节全在这里了
前言 在这篇文章详细说了该如何去复习,之前也答应各位把面经整理一下,但是因为入职的事情耽搁了,现在整理出来回馈给大家! 美团 一面 0.自我介绍1.问项目(项目详细介绍.用到什么技术.有什么优化)2. ...
- MathType输入几何符号的技巧
通过学习几何学的知识,我们发现其中包含的几何符号有很多,比如有表示图形的符号,如三角形,平行四边形,圆,角,圆弧等:还有表示位置关系的符号,如平行,垂直等:还有表示矢量等其他符号,那么MathType ...
- 使用iOS 设备管理器 iMazing导出苹果设备中的录音文件
iMazing是一款功能强大的苹果设备管理软件,能为用户提供便捷的录音文件导出功能.用户可以直接将录音文件从苹果设备中导出,接下来,就让小编为大家演示一下如何操作吧. 图1:iMazing界面 1.打 ...
- 手把手为大家演示fat32转ntfs操作过程,一看就会
fat32和ntfs是两种我们较为常见的u盘或者硬盘格式.它们都有着各自的特点,但是相比之下,使用ntfs文件格式我们可以做出很多fat32不能实现的功能.在日常生活中,我们会面临到需要把fat32转 ...
- 前端(web)知识-html
前端由三部分组成: HTML(标签)--CSS(美化,修饰)--JS(执行指令) HTML(超文本标记语言,Hypertext Markup Language):是一种用于创建网页的标记语言. 本质上 ...
- web自动化测试难点 滚动条操作、日期框处理、上传文件
如何把页面滑到最低部? 一般来说,做web自动化测试时,不需要单独写代码,把页面滑到可见,因为click操作,只要是元素存在并且加载出来了,就可以点击到,无需另外写滑动元素的代码. 如果特殊情况需要滑 ...
- Java中类加载的过程
类加载过程 这里的加载过程是严格按照加载开始顺序进行的,注意是加载开始而不是加载完成.也就是有可能会有两个或几个阶段是同时进行的. 比如下面提到的验证过程中的符号引用验证是在解析阶段开始之后进行. 加 ...
- selenium WebDriver提示Unable to find a matching set of capabilities解决方法
问题出在:应该将火狐浏览器驱动添加到火狐浏览器安装目录下,并且将火狐浏览器安装目录放在path下面.(出现大意,忘了在火狐浏览器下放其对应的驱动) 亲测以下组合方式可用: pycharm-comm ...