2436: [Noi2011]Noi嘉年华 - BZOJ
Description
NOI2011 在吉林大学开始啦!为了迎接来自全国各地最优秀的信息学选手,
吉林大学决定举办两场盛大的 NOI 嘉年华活动,分在两个不同的地点举办。每
个嘉年华可能包含很多个活动,而每个活动只能在一个嘉年华中举办。
现在嘉年华活动的组织者小安一共收到了 n个活动的举办申请,其中第 i 个
活动的起始时间为 Si,活动的持续时间为Ti。这些活动都可以安排到任意一个嘉
年华的会场,也可以不安排。
小安通过广泛的调查发现,如果某个时刻,两个嘉年华会场同时有活动在进
行(不包括活动的开始瞬间和结束瞬间),那么有的选手就会纠结于到底去哪个
会场,从而变得不开心。所以,为了避免这样不开心的事情发生,小安要求不能
有两个活动在两个会场同时进行(同一会场内的活动可以任意进行)。
另外,可以想象,如果某一个嘉年华会场的活动太少,那么这个嘉年华的吸
引力就会不足,容易导致场面冷清。所以小安希望通过合理的安排,使得活动相
对较少的嘉年华的活动数量最大。
此外,有一些活动非常有意义,小安希望能举办,他希望知道,如果第i 个
活动必须举办(可以安排在两场嘉年华中的任何一个),活动相对较少的嘉年华
的活动数量的最大值。
Input
输入的第一行包含一个整数 n,表示申请的活动个数。
接下来 n 行描述所有活动,其中第 i 行包含两个整数 Si、Ti,表示第 i 个活
动从时刻Si开始,持续 Ti的时间。
Output
输出的第一行包含一个整数,表示在没有任何限制的情况下,活动较少的嘉
年华的活动数的最大值。
接下来 n 行每行一个整数,其中第 i 行的整数表示在必须选择第 i 个活动的
前提下,活动较少的嘉年华的活动数的最大值。
Sample Input
5
8 2
1 5
5 3
3 2
5 3
Sample Output
2
2
1
2
2
2
HINT
在没有任何限制的情况下,最优安排可以在一个嘉年华安排活动 1, 4,而在
另一个嘉年华安排活动 3, 5,活动2不安排。
1≤n≤200 0≤Si≤10^9
1≤Ti≤ 10^9
DP题,首先离散化
首先我们可以想象分配方案应该是交替的一段一段的
所以我们设f[i,j]为时间i前一个会场选j个活动,另一个会场最多有多少活动,那么f[i,j]=max{f[k,j]+s[k,i],f[k,j-s[k,i]]}
然后第一问的答案就是max{min(f[n*2,i],i)}
第二问是要求必选一个,那么我们想像这一个一定在方案中的某一段中
假设区间是(i,j),那么最优值是g[i,j],我们预处理出所有的g[i,j]就可以n^3回答所有的询问了
然后我们现在要考虑的是怎么算g[i,j]
因为去掉(i,j)变成左边和右边两部分,所以开始我们dp两次,一个从左边开始一个从右边开始,就可以算g[i,j]了
g[i,j]=max{min(x+y+s[i,j],l[i,x]+r[j,y])}
但是直接枚举是不行的(艹,还让不让人愉快的做题了......)
但是其实x固定,关于y是单峰函数,而且x增大的话,最优值y会减小(因为要尽量平衡),然后就可以x for一遍,y一直递减就行了
所以n^3可以预处理出g[i,j],然后就做完了(wikioi过不去,又用优化代码过去了233,在我之前没有pascal在wikioi过的)
const
maxn=;
var
a,b:array[..maxn,..]of longint;
s,l,r,f:array[..maxn,..maxn]of longint;
n,k,cnt:longint; procedure up(var x:longint;y:longint);
begin
if x<y then x:=y;
end; function min(x,y:longint):longint;
begin
if x<y then exit(x);
exit(y);
end; procedure main;
var
i,j,g,x,y,minx,ans:longint;
begin
read(n);
for i:= to n do
begin
read(a[i,],a[i,]);
inc(a[i,],a[i,]);
end;
while cnt<n<< do
begin
minx:=maxlongint;inc(k);
for i:= to n do
for j:= to do
if (b[i,j]=) and (a[i,j]<minx) then minx:=a[i,j];
for i:= to n do
for j:= to do
if (a[i,j]=minx) and (b[i,j]=) then
begin
inc(cnt);b[i,j]:=;
a[i,j]:=k;
end;
end;
for i:= to n do inc(s[a[i,],a[i,]]);
for i:= to k do
for j:=i+ to k do
inc(s[i,j],s[i,j-]);
for j:= to k do
for i:=j downto do
inc(s[i-,j],s[i,j]);
fillchar(l,sizeof(l),);
fillchar(r,sizeof(r),);
l[,]:=;r[k+,]:=;
for i:= to k do
for j:= to n do
for g:= to i- do
begin
up(l[i,j],l[g,j]+s[g,i]);
if j>=s[g,i] then up(l[i,j],l[g,j-s[g,i]]);
end;
for i:=k downto do
for j:= to n do
for g:=i+ to k+ do
begin
up(r[i,j],r[g,j]+s[i,g]);
if j>=s[i,g] then up(r[i,j],r[g,j-s[i,g]]);
end;
ans:=;
for i:= to n do
up(ans,min(l[k,i],i));
writeln(ans);
for i:= to k do
for j:=i to k do
begin
y:=s[j,k];
for x:= to s[,i] do
begin
while (y>) and (min(x+y-+s[i,j],l[i,x]+r[j,y-])>=min(x+y+s[i,j],l[i,x]+r[j,y])) do dec(y);
up(f[i,j],min(x+y+s[i,j],l[i,x]+r[j,y]));
end;
end;
for i:= to n do
begin
ans:=;
for x:= to a[i,] do
for y:=a[i,] to k do
up(ans,f[x,y]);
writeln(ans);
end;
end; begin
main;
end.
2436: [Noi2011]Noi嘉年华 - BZOJ的更多相关文章
- 【BZOJ 2436】 2436: [Noi2011]Noi嘉年华 (区间DP)
2436: [Noi2011]Noi嘉年华 Description NOI2011 在吉林大学开始啦!为了迎接来自全国各地最优秀的信息学选手,吉林大学决定举办两场盛大的 NOI 嘉年华活动,分在两个不 ...
- bzoj 2436: [Noi2011]Noi嘉年华
Description NOI2011 在吉林大学开始啦!为了迎接来自全国各地最优秀的信息学选手,吉林大学决定举办两场盛大的 NOI 嘉年华活动,分在两个不同的地点举办.每个嘉年华可能包含很多个活动, ...
- luogu P1973 [NOI2011]NOI 嘉年华 dp
LINK:NOI 嘉年华 一道质量非常高的dp题目. 考虑如何求出第一问 容易想到dp. 按照左端点排序/右端点排序状态还是很难描述. 但是我们知道在时间上肯定是一次选一段 所以就可以直接利用时间点来 ...
- NOI2011 NOI嘉年华
http://www.lydsy.com/JudgeOnline/problem.php?id=2436 首先离散化,离散化后时间范围为[1,cnt]. 求出H[i][j],表示时间范围在[i,j]的 ...
- bzoj2436: [Noi2011]Noi嘉年华
我震惊了,我好菜,我是不是该退役(苦逼) 可以先看看代码里的注释 首先我们先考虑一下第一问好了真做起来也就这个能想想了 那么离散化时间是肯定的,看一手范围猜出是二维DP,那对于两个会场,一个放自变量, ...
- 洛谷P1973 [NOI2011]Noi嘉年华(动态规划,决策单调性)
洛谷题目传送门 DP题怕是都要大大的脑洞...... 首先,时间那么大没用,直接离散化. 第一问还好.根据题意容易发现,当一堆活动的时间有大量重叠的时候,更好的办法是把它们全部安排到一边去.那么我们转 ...
- BZOJ2436 [Noi2011]Noi嘉年华 【dp】
题目链接 BZOJ2436 题解 看这\(O(n^3)\)的数据范围,可以想到区间\(dp\) 发现同一个会场的活动可以重叠,所以暴力求出\(num[l][r]\)表示离散化后\([l,r]\)的完整 ...
- 洛谷P1973 [NOI2011]Noi嘉年华(决策单调性)
传送门 鉴于FlashHu大佬讲的这么好(而且我根本不会)我就不再讲一遍了->传送 //minamoto #include<iostream> #include<cstdio& ...
- cogs 1377. [NOI2011] NOI嘉年华 (dp
题意:给你n个活动的起止时间,要你从中选一些活动在2个会场安排(不能有两个活动在两个会场同时进行),使活动较少的会场活动数最大,以及在某个活动必须选择的前提下,求该答案. 思路:由于n很小,时间很大, ...
随机推荐
- 【学习笔记】【C语言】指向结构体的指针
1.指向结构体的指针的定义 struct Student *p; 2.利用指针访问结构体的成员 1> (*p).成员名称 2> p->成员名称 3.代码 #include < ...
- 【学习笔记】【C语言】关键字
1.关键字就是C语言提供的有特殊含义的符号,也叫做“保留字” *C语言一共提供了32个关键字,这些关键字都被C语言赋予了特殊含义 auto double int struct break else l ...
- 20141201--JS Window
一.window.screen 包含有关用户屏幕的信息. window.screen 对象在编写时可以不使用 window 这个前缀. 一些属性: screen.availWidth - 可用的屏幕宽 ...
- UI3_ViewController初步
// // AppDelegate.m // UI3_ViewController初步 // // Created by zhangxueming on 15/6/30. // Copyright ( ...
- Vim 保存和退出命令
命令 简单说明 :w 保存编辑后的文件内容,但不退出vim编辑器.这个命令的作用是把内存缓冲区中的数据写到启动vim时指定的文件中. :w! 强制写文件,即强制覆盖原有文件.如果原有文件的访问权限不允 ...
- Oracle 创建用户授权
权限: create session create table unlimited tablespace connect resource dba 例: #sqlplus /nolog SQL> ...
- linux命令之grep用法介绍
Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹 配的行打印出来.grep全称是Global Regular Expression Print,表示全局正则表达 ...
- <Linux系统hostname命令详解>
hostname命令的用法的小知识我们都知道hostname命令是查看主机名和修改主机名的. [root@apache ~]# hostname //查看本机的主机名apache.example.c ...
- 《搭建DNS内外网的解析服务》RHEL6
首先说下: 搭建的这个dns内外网的解析,是正向解析,反向解析自己根据正向解析把文件颠倒下就ok了 第一步我们先搭建一个DNS的正反向解析(参考上篇DNS正反向解析,这是上篇做过的) 第二部才是搭建内 ...
- 批处理测试局域网网络连通性ping1-255
for /l %%1 in (1 1 255)do ping /n 1 192.168.1.%%1 ##bat下 运行 for /l %i in (1,1,254) do ping -n ...