题目:http://www.lydsy.com/JudgeOnline/problem.php?id=1178

看ppt
http://wenku.baidu.com/link?url=dJv6LNme7syiLGM-TzbEEKXwx36JWEnI5HFrIlzfmzUXXg4HG8FDggj5WQS3EKL3k3p-sUYeJ268jCvN4t_kq2YPo3I4GXvaGulQjXrO3d7
#include<cstdio>
#include<cstdlib>
#include<iostream>
#include<fstream>
#include<algorithm>
#include<cstring>
#include<string>
#include<cmath>
#include<queue>
#include<stack>
#include<map>
#include<utility>
#include<set>
#include<bitset>
#include<vector>
#include<functional>
#include<deque>
#include<cctype>
#include<climits>
#include<complex>
//#include<bits/stdc++.h>适用于CF,UOJ,但不适用于poj using namespace std; typedef long long LL;
typedef double DB;
typedef pair<int,int> PII;
typedef complex<DB> CP; #define mmst(a,v) memset(a,v,sizeof(a))
#define mmcy(a,b) memcpy(a,b,sizeof(a))
#define re(i,a,b) for(i=a;i<=b;i++)
#define red(i,a,b) for(i=a;i>=b;i--)
#define fi first
#define se second
#define m_p(a,b) make_pair(a,b)
#define SF scanf
#define PF printf
#define two(k) (1<<(k)) template<class T>inline T sqr(T x){return x*x;}
template<class T>inline void upmin(T &t,T tmp){if(t>tmp)t=tmp;}
template<class T>inline void upmax(T &t,T tmp){if(t<tmp)t=tmp;} const DB EPS=1e-;
inline int sgn(DB x){if(abs(x)<EPS)return ;return(x>)?:-;}
const DB Pi=acos(-1.0); inline int gint()
{
int res=;bool neg=;char z;
for(z=getchar();z!=EOF && z!='-' && !isdigit(z);z=getchar());
if(z==EOF)return ;
if(z=='-'){neg=;z=getchar();}
for(;z!=EOF && isdigit(z);res=res*+z-'',z=getchar());
return (neg)?-res:res;
}
inline LL gll()
{
LL res=;bool neg=;char z;
for(z=getchar();z!=EOF && z!='-' && !isdigit(z);z=getchar());
if(z==EOF)return ;
if(z=='-'){neg=;z=getchar();}
for(;z!=EOF && isdigit(z);res=res*+z-'',z=getchar());
return (neg)?-res:res;
} const int maxN=;
const int maxcnt=*maxN;
const int INF=; int N;
struct Ta
{
int l,r,id;
inline friend bool operator < (Ta x,Ta y){return x.l<y.l;}
inline Ta(int _l=,int _r=,int _id=){l=_l;r=_r;id=_id;}
}a[maxN+],temp[maxN+]; int flag[maxN+];
int ans;
PII fin[maxN+];int tol; int cnt,bak[maxcnt+]; inline bool cmpr(Ta x,Ta y){return x.r<y.r;} int tree[maxcnt+]; int next[maxN+];
int jump[maxN+][]; #define lowbit(a) (a&(-a))
inline int ask(int p)
{
p=cnt-p+;
int res=INF;
for(;p>=;p-=lowbit(p))upmin(res,tree[p]);
return res;
}
inline void update(int p,int v)
{
p=cnt-p+;
for(;p<=cnt;p+=lowbit(p))upmin(tree[p],v);
} PII tr[*maxcnt+];
inline void down(int root,int l,int r,int mid)
{
if(tr[root]!=PII(,))
{
tr[root*]=tr[root*+]=tr[root];
tr[root]=PII(,);
}
}
inline void askf(int root,int l,int r,int p,int &x,int &y)
{
if(l>r || p<l || r<p) return;
if(p<=l && r<=p) {x=tr[root].fi;y=tr[root].se;return;}
int mid=(l+r)/;
down(root,l,r,mid);
if(p<=mid) askf(root*,l,mid,p,x,y); else askf(root*+,mid+,r,p,x,y);
}
inline void updatef(int root,int l,int r,int x,int y,PII val)
{
if(l>r || x>y || r<x || y<l)return;
if(x<=l && r<=y){tr[root]=val;return;}
int mid=(l+r)/;
down(root,l,r,mid);
updatef(root*,l,mid,x,y,val);
updatef(root*+,mid+,r,x,y,val);
} inline int solve(int x,int y)
{
if(x>y)return ;
int res=,i,p=lower_bound(a+,a+N+,Ta(x,,))-a;
if(p>N)return ;
red(i,,)
if(jump[p][i]!= && a[jump[p][i]].r<=y)
{
res+=two(i);
p=jump[p][i];
}
if(a[p].r<=y)res++;
return res;
}
inline int check(int x,int y,int l,int r)
{
int t1=solve(x,y);
int t2=solve(x,l-);
int t3=solve(r+,y);
return solve(x,y)==solve(x,l-)++solve(r+,y);
} int main()
{
freopen("bzoj1178.in","r",stdin);
freopen("bzoj1178.out","w",stdout);
int i,j;
N=gint();
re(i,,N)a[i].l=gint(),a[i].r=gint(),a[i].id=i;
re(i,,N)bak[++cnt]=a[i].l,bak[++cnt]=a[i].r;
sort(bak+,bak+cnt+);
cnt=unique(bak+,bak+cnt+)-bak-;
re(i,,N)a[i].l=lower_bound(bak+,bak+cnt+,a[i].l)-bak,a[i].r=lower_bound(bak+,bak+cnt+,a[i].r)-bak;
re(i,,N)fin[a[i].id]=PII(a[i].l,a[i].r);
tol=N;
sort(a+,a+N+,cmpr);
int t=;
re(i,,N){if(a[i].l<=t)flag[i]=;upmax(t,a[i].l);}
int ge=;
re(i,,N)if(!flag[i])temp[++ge]=a[i];
N=ge;
re(i,,N)a[i]=temp[i];
t=;
re(i,,N)if(t<a[i].l){ans++;t=a[i].r;}
cout<<ans<<endl;
re(i,,cnt)tree[i]=INF;
red(i,N,)
{
next[i]=ask(a[i].r+);if(next[i]==INF) next[i]=;
update(a[i].l,i);
}
red(i,N,)
{
jump[i][]=next[i];
re(j,,)jump[i][j]=jump[jump[i][j-]][j-];
}
re(i,,*maxcnt+-)tr[i]=PII(,cnt);
re(i,,tol)
{
int l=fin[i].fi,r=fin[i].se,x,y;
askf(,,cnt,l,x,y);
if(x==- && y==-)continue;
if(!(x<=l && r<=y))continue;
if(check(x,y,l,r))
{
printf("%d ",i);
ans--;if(ans==)break;
updatef(,,cnt,l,r,PII(-,-));
updatef(,,cnt,x,l-,PII(x,l-));
updatef(,,cnt,r+,y,PII(r+,y));
}
}
printf("\n");
return ;
}

bzoj1178的更多相关文章

  1. BZOJ1178 [Apio2009]CONVENTION会议中心 贪心 set

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1178 题意概括 一堆线段,现在取出最多条数,使其互不覆盖,并输出字典序最小的方案. 题解 这题好坑 ...

  2. [BZOJ1177][BZOJ1178][BZOJ1179]APIO2009解题报告

    抱着好奇心态去开始做APIO的往年试题感受一下难度 Oil Description 采油区域 Siruseri政府决定将石油资源丰富的Navalur省的土地拍卖给私人承包商以建立油井.被拍卖的整块土地 ...

  3. 【BZOJ-1178】CONVENTION会议中心 倍增 + set (神思路好题!)

    1178: [Apio2009]CONVENTION会议中心 Time Limit: 15 Sec  Memory Limit: 162 MBSubmit: 812  Solved: 323[Subm ...

  4. 【bzoj1178】 Apio2009—CONVENTION会议中心

    http://www.lydsy.com/JudgeOnline/problem.php?id=1178 (题目链接) 题意 给出n个区间,问在区间两两不相交的情况下最多能选出多少区间,并输出字典序最 ...

  5. BZOJ1178 [Apio2009]CONVENTION会议中心

    本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转载请注明出处,侵权必究,保留最终解释权! Description Siruseri政府建造了 ...

  6. BZOJ1178 APIO2009 会议中心 贪心、倍增

    传送门 只有第一问就比较水了 每一次贪心地选择当前可以选择的所有线段中右端点最短的,排序之后扫一遍即可. 考虑第二问.按照编号从小到大考虑每一条线段是否能够被加入.假设当前选了一个区间集合\(T\), ...

  7. BZOJ1178或洛谷3626 [APIO2009]会议中心

    BZOJ原题链接 洛谷原题链接 第一个问题是经典的最多不相交区间问题,用贪心即可解决. 主要问题是第二个,求最小字典序的方案. 我们可以尝试从\(1\to n\)扫一遍所有区间,按顺序对每一个不会使答 ...

  8. bzoj1178/luogu3626 会议中心 (倍增+STL::set)

    贪心地,可以建出一棵树,每个区间对应一个点,它的父亲是它右边的.与它不相交的.右端点最小的区间. 为了方便,再加入一个[0,0]区间 于是就可以倍增来做出从某个区间开始,一直到某个右界,这之中最多能选 ...

  9. bzoj1178 [Apio2009]CONVENTION会议中心 区间dp+贪心

    [Apio2009]CONVENTION会议中心 Time Limit: 15 Sec  Memory Limit: 162 MBSubmit: 1130  Solved: 444[Submit][S ...

随机推荐

  1. Hadoop生态圈技术图谱

    当下Hadoop已经成长为一个庞大的体系,貌似只要和海量数据相关的,没有哪个领域缺少Hadoop的身影,下面是一个Hadoop生态系统的图谱,详细的列举了在Hadoop这个生态系统中出现的各种数据工具 ...

  2. ubuntu下安装pdo扩展

    ubuntu下安装好LAMP后默认情况没有安装mysql_pdo扩展,以下是安装 步聚,在终端输入以下命令 1.pecl search pdo 2.sudo pecl install pdo 当出现E ...

  3. MVC 模板页和布局

    我们在以前的Asp.NET课程中已经学习过母版页了,在MVC中WebForm视图使用母版页的方法与以前基本相同. 创建一个项目MvcMasterPageDemo. 添加Home控制器,生成Index视 ...

  4. Django之路由系统

    一.路由系统介绍 在django程序中,可以通过urls.py文件对所有的url进行任务的分配,根据路由规则的定义选择不同的业务处理函数进行处理 二.路由规则定义 1.路由规则代码如下,mysite/ ...

  5. 关于IE8导航串行的问题

    1.概述: 作为一个前端人员,多浏览器兼容是必须必备的技能,现在一般要求是兼容IE8及以上,如果兼容IE6的话,会麻烦一些,这里介绍的是在IE8状态下我们导航条错位的问题. 2.导航错位代码 < ...

  6. Javascript:sort()方法快速实现对数组排序

    定义和用法: sort() 方法用于对数组的元素进行排序. 语法: arrayObject.sort(sortby) 注释:sortby,可选,规定排序顺序,必须是函数. 说明: 如果调用该方法时没有 ...

  7. Gson序列化对象时排除字段

    import com.google.gson.ExclusionStrategy; import com.google.gson.FieldAttributes; /** *Gson序列化对象排除属性 ...

  8. Android Studio 初体验

    Google在I/O */

  9. C#。1 数据类型,常量变量,类型转换

    C#. 一.数据类型 1,字符串类型(string) .放入一串字符串,需要用""引起来. 列如: string a ="999"; 2,整型 (int).   ...

  10. 【转】asp.net 利用Global.asax 捕获整个解决方案中的异常错误

    之前做项目的时候都是在每个页面中处理这不同的异常信息,一个页面数下来,很多个try{}catch{}语句块,令整个代码结构有些不够美观. 今天看到一篇帖子,是关于利用全局应用程序类来帮忙获取异常信息, ...