[bzoj1178]会议中心
考虑用f[i][j]表示以i为起点(i是时间,所以要离散)选$2^j$条线段(这里不是时间)最小的终点,预处理用倍增的方式来求即可
预处理出这个数组后,就可以很快的求出在$[l,r]$的时间内最多能选多少条线段,类似于树上的倍增(注意判断超过最大时间的情况)
然后从前往后枚举每一段时间,考虑能否加入,当且仅当其分割的那个区间的两部分的答案之和+1=原区间的答案,找区间可以用两个set(分别维护起点和终点)来搞

1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 200005
4 struct ji{
5 int l,r;
6 bool operator < (const ji &k)const{
7 return (l<k.l)||(l==k.l)&&(r<k.r);
8 }
9 }a[N],aa[N];
10 set<int>s1,s2;
11 int n,m,b[N<<1],f[N<<1][21];
12 void build(){
13 memcpy(aa,a,sizeof(a));
14 sort(aa+1,aa+n+1);
15 aa[n+1].l=aa[n+1].r=m+1;
16 for(int i=1,j=1;i<=m;i++){
17 while (i>aa[j].l)j++;
18 f[i][0]=aa[j].r;
19 }
20 for(int i=m-1;i;i--)f[i][0]=min(f[i][0],f[i+1][0]);
21 for(int i=0;i<=20;i++)f[m+1][i]=m+1;
22 for(int j=1;j<=20;j++)
23 for(int i=1;i<=m;i++)f[i][j]=f[min(m,f[i][j-1])+1][j-1];
24 }
25 int query(int l,int r){
26 int ans=0;
27 for(int i=20;i>=0;i--)
28 if (f[l][i]<=r){
29 l=min(m,f[l][i])+1;
30 ans+=(1<<i);
31 }
32 return ans;
33 }
34 int main(){
35 scanf("%d",&n);
36 for(int i=1;i<=n;i++){
37 scanf("%d%d",&a[i].l,&a[i].r);
38 b[++b[0]]=a[i].l;
39 b[++b[0]]=a[i].r;
40 }
41 sort(b+1,b+2*n+1);
42 m=unique(b+1,b+2*n+1)-b-1;
43 for(int i=1;i<=n;i++){
44 a[i].l=lower_bound(b+1,b+m+1,a[i].l)-b;
45 a[i].r=lower_bound(b+1,b+m+1,a[i].r)-b;
46 }
47 build();
48 printf("%d\n",query(1,m));
49 bool flag=0;
50 s1.insert(1);
51 s2.insert(m);
52 for(int i=1;i<=n;i++){
53 if ((!s1.size())||(*s1.begin()>a[i].l)||(*--s2.end()<a[i].r))continue;
54 int x=*--s1.upper_bound(a[i].l),y=*s2.lower_bound(a[i].r);
55 if ((x!=*--s1.end())&&(*s1.upper_bound(a[i].l)<=y))continue;
56 if (query(x,y)==query(x,a[i].l-1)+1+query(a[i].r+1,y)){
57 if (a[i].r==y)s2.erase(y);
58 else s1.insert(a[i].r+1);
59 if (a[i].l==x)s1.erase(x);
60 else s2.insert(a[i].l-1);
61 if (flag)printf(" ");
62 flag=1;
63 printf("%d",i);
64 }
65 }
66 }
[bzoj1178]会议中心的更多相关文章
- 【BZOJ-1178】CONVENTION会议中心 倍增 + set (神思路好题!)
1178: [Apio2009]CONVENTION会议中心 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 812 Solved: 323[Subm ...
- BZOJ1178 [Apio2009]CONVENTION会议中心
本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转载请注明出处,侵权必究,保留最终解释权! Description Siruseri政府建造了 ...
- bzoj1178 [Apio2009]CONVENTION会议中心 区间dp+贪心
[Apio2009]CONVENTION会议中心 Time Limit: 15 Sec Memory Limit: 162 MBSubmit: 1130 Solved: 444[Submit][S ...
- [APIO2009]会议中心
[APIO2009]会议中心 题目大意: 原网址与样例戳我! 给定n个区间,询问以下问题: 1.最多能够选择多少个不相交的区间? 2.在第一问的基础上,输出字典序最小的方案. 数据范围:\(n \le ...
- 【BZOJ】【1178】【APIO2009】convention会议中心
贪心 如果不考虑字典序的话,直接按右端点排序,能选就选,就可以算出ans…… 但是要算一个字典序最小的解就比较蛋疼了= = Orz了zyf的题解 就是按字典序从小到大依次枚举,在不改变答案的情况下,能 ...
- 1178: [Apio2009]CONVENTION会议中心
1178: [Apio2009]CONVENTION会议中心 https://lydsy.com/JudgeOnline/problem.php?id=1178 分析: set+倍增. 首先把所有有包 ...
- 会议中心[APIO2009]
会议中心 思路 这一题的正解是倍增的,但是由于我太蒟蒻了,所以我选了一个不算正解但是有可以拿满分的题目学习 思路和我考场上其实差不多,只是我无法实现.... 下面我先来介绍几个数组的用途 1.s,s数 ...
- 【题解】[APIO2009]会议中心
[题解][P3626 APIO2009]会议中心 真的是一道好题!!!刷新了我对倍增浅显的认识. 此题若没有第二份输出一个字典序的方案,就是一道\(sort+\)贪心,但是第二问使得我们要用另外的办法 ...
- [APIO2009]会议中心(贪心)
P3626 [APIO2009]会议中心 题目描述 Siruseri 政府建造了一座新的会议中心.许多公司对租借会议中心的会堂很 感兴趣,他们希望能够在里面举行会议. 对于一个客户而言,仅当在开会时能 ...
随机推荐
- 项目实战 Prometheus环境搭建
项目摘要: 本文是搭建一套prometheus环境的教程. 前期准备:准备三台虚拟机,本文以centos7为例. 项目具体实施:分别进入每台虚拟机设置hostname:# hostnamectl se ...
- 【UE4 设计模式】装饰器模式 Decorator Pattern
概述 描述 动态地给一个对象增加一些额外的职责(Responsibility),就增加对象功能来说,装饰模式比生成子类实现更为灵活.是一种对象结构型模式. 套路 抽象构件(Component) 具体构 ...
- Codeforces1573B
### 问题描述 - 给你两个数组,a数组里面是1 - 2n中的奇数任意顺序排列组成,b数组里面是1 - 2n中的奇数任意顺序排列组成. - 问你最少需要多少次操作能让a的字典序小于b. ### 思路 ...
- Java中的函数式编程(八)流Stream并行编程
写在前面 在本系列文章的第一篇,我们提到了函数式编程的优点之一是"易于并发编程". Java作为一个多线程的语言,它通过 Stream 来提供了并发编程的便利性. 题外话: 严格来 ...
- 航胥:北航教务助手——Alpha阶段发布声明
本软件项目为北京航空航天大学2020年"软件工程"课程项目 v1.0.5版本下载地址:https://bhpan.buaa.edu.cn:443/#/link/D10B71B69E ...
- BUAA 2020 软件工程 软件分析案例作业
Author: 17373051 郭骏 项目 内容 这个作业属于哪个课程 2020春季计算机学院软件工程(罗杰 任健) 这个作业的要求在哪里 个人博客作业-软件分析案例 我在这个课程的目标是 学习软件 ...
- 8.18考试总结[NOIP模拟43]
又挂了$80$ 好气哦,但要保持优雅.(草 T1 地衣体 小小的贪心:每次肯定从深度较小的点向深度较大的点转移更优. 模拟一下,把边按链接点的子树最大深度排序,发现实际上只有上一个遍历到的点是对当前考 ...
- 电脑cmd命令快速查看连接过的WIFI密码信息
只是突然发现,好奇心作怪,试了一下,妈妈再也不用担心我忘记家里的wifi密码了 1.直接打开"运行"(win键+R) 2.输入CMD 确定 3.输入下面cmd命令.鼠标粘贴 for ...
- 在Ubuntu下安装Solr
使用wget命令去官网下载solr的压缩包. 1 wget https://mirrors.bfsu.edu.cn/apache/lucene/solr/8.6.3/solr-8.6.3.tgz 使用 ...
- IDA*、剪枝、较难搜索、扫描——DNA sequence HDU - 1560
万恶之源 翻译 题意就是给出N个DNA序列,要求出一个包含这n个序列的最短序列是多长 这是一道搜索题,为什么呢?从样例可以感受到,我们应该从左往右"扫描",从n个DNA序列中取出某 ...