ZOJ 3953 Intervals
线段树,排序。
按照$R$从小到大排序之后逐个检查,如果$L$,$R$最大值不超过$2$,那么就把这个区间放进去,区间$+1$,否则不能放进去。
#include<bits/stdc++.h>
using namespace std; int T,n,sz;
int a[];
struct X { int L,R,id; }s[];
int f[],m[];
int P; bool cmp(X a,X b)
{
return a.R<b.R;
} int get(int x)
{
int ll=,rr=sz,res;
while(ll<=rr)
{
int mid = (ll+rr)/;
if(a[mid]>x) rr=mid-;
else if(a[mid]==x) return mid;
else ll=mid+;
}
} void pushDown(int rt)
{
if(f[rt]==) return ;
f[*rt]+=f[rt];
f[*rt+]+=f[rt];
m[*rt]+=f[rt];
m[*rt+]+=f[rt];
f[rt]=;
} void update(int L,int R,int val,int l,int r,int rt)
{
if(L<=l&&r<=R)
{
f[rt]+=val;
m[rt]+=val;
return ;
} pushDown(rt);
int mid = (l+r)/;
if(L<=mid) update(L,R,val,l,mid,*rt);
if(R>mid) update(L,R,val,mid+,r,*rt+);
m[rt] = max(m[*rt],m[*rt+]);
} void query(int L,int R,int l,int r,int rt)
{
if(L<=l&&r<=R)
{
P=max(P,m[rt]);
return ;
} pushDown(rt);
int mid = (l+r)/;
if(L<=mid) query(L,R,l,mid,*rt);
if(R>mid) query(L,R,mid+,r,*rt+);
m[rt] = max(m[*rt],m[*rt+]);
} void build(int l,int r,int rt)
{
m[rt] = ;
f[rt] = ;
if(l==r) return ; int mid = (l+r)/;
build(l,mid,*rt);
build(mid+,r,*rt+);
} int ans[],q; int main()
{
scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
sz=;
for(int i=;i<=n;i++)
{
scanf("%d%d",&s[i].L,&s[i].R);
sz++; a[sz]=s[i].L;
sz++; a[sz]=s[i].R;
} sort(a+,a++sz); for(int i=;i<=n;i++)
{
s[i].L=get(s[i].L);
s[i].R=get(s[i].R);
s[i].id=i;
} sort(s+,s++n,cmp); q=; build(,sz,); for(int i=;i<=n;i++)
{
P=;
query(s[i].L,s[i].R,,sz,);
if(P==)
{
ans[q++]=s[i].id;
continue;
}
else update(s[i].L,s[i].R,,,sz,);
} sort(ans,ans+q);
printf("%d\n",q);
for(int i=;i<q;i++)
{
printf("%d",ans[i]);
if(i<q-) printf(" ");
}
printf("\n"); }
return ;
}
ZOJ 3953 Intervals的更多相关文章
- ZOJ - 3953 Intervals 【贪心】
题目链接 http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3953 题意 给出N个区间,求去掉某些区间,使得剩下的区间中,任何 ...
- Intervals ZOJ - 3953 (区间贪心)
Chiaki has n intervals and the i-th of them is [li, ri]. She wants to delete some intervals so that ...
- ZOJ 3953:Intervals(优先队列+思维)
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=5572 题意:给出n个线段,问最少删除几个线段可以使得任意一个点不会被三个以上的 ...
- POJ 1201 & HDU1384 & ZOJ 1508 Intervals(差分约束+spfa 求最长路径)
题目链接: POJ:http://poj.org/problem?id=1201 HDU:http://acm.hdu.edu.cn/showproblem.php? pid=1384 ZOJ:htt ...
- 扫描线(线段树)+贪心 ZOJ 3953
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=5572 Intervals Time Limit: 1 Second ...
- zoj 1508 Intervals (差分约束)
Intervals Time Limit: 10 Seconds Memory Limit: 32768 KB You are given n closed, integer interva ...
- poj 1201/zoj 1508 intervals 差分约束系统
// 思路 : // 图建好后 剩下的就和上一篇的 火烧连营那题一样了 求得解都是一样的 // 所以稍微改了就过了 // 最下面还有更快的算法 速度是这个算法的2倍#include <ios ...
- zoj3953 Intervals 最大不重叠区间加强版 zoj排名第一~
Intervals Time Limit: 1 Second Memory Limit:65536 KB Special Judge Chiaki has n intervals ...
- zoj 1508 poj 1201 Intervals
差分约束系统. #include<cstdio> #include<cstring> #include<cmath> #include<vector> ...
随机推荐
- [吴恩达机器学习笔记]12支持向量机4核函数和标记点kernels and landmark
12.支持向量机 觉得有用的话,欢迎一起讨论相互学习~Follow Me 12.4 核函数与标记点- Kernels and landmarks 问题引入 如果你有以下的训练集,然后想去拟合其能够分开 ...
- 获取Session和request方法
action中的几种写法 //第一种很少用public class LoginAction1 extends ActionSupport { private Map request; ...
- codeblocks 设置代码自动补全
熟悉使用一些开发类IDE的朋友对代码自动补全一定印象深刻,如Visual studio,eclipse等,我们在程序中定义的那一个个超长的变量函数名只需打出几个字母就可自动补全,但是在codebloc ...
- [oracle]centos 7 安装oracle
换了好几个系统终于还是利用centos安装oralce成功了,这里我也参考了网上的好多资料以及oracle的官方文档 1.下载oracle,我这里选择的是11gr2版本,下载下来后有两个文件,利用un ...
- 【bzoj】2326 [HNOI2011]数学作业
[题意]给定n和m,求1~n从高位到低位连接%m的结果.n=11时,ans=1234567891011%m.n<=10^18,m<=10^9. [算法]递推+矩阵快速幂 [题解] 考虑枚举 ...
- [BZOJ2809&1455&1367]解题报告|可并堆
其实非常好理解..就是可以可以合并起来的两个堆嘛>< 2809: [Apio2012]dispatching Description 在一个忍者的帮派里,一些忍者们被选中派遣给顾客,然后依 ...
- php通过composer添加一个包以后,无法通过git将这个包的代码文件提交上去
实际上是因为 vender 包中包含 有.git 文件,是composer 下载时下载了 该项目的github源码. 就是参数 源码优先 --prefer-source composer update ...
- 黑色的cms商城网站后台管理模板——后台
链接:http://pan.baidu.com/s/1hst6Lbm 密码:9ad7
- webpack中的静态资源处理
你可能已经注意到,在我们的项目结构里,有两个静态文件的路径,分别是:src/assets 和 static/.那这两个到底有什么区别呢? Webpacked 资源 为了回答这个问题,我们首先需要理解w ...
- perl6正则 4: before / after 代码断言: <?{}> / <!{}>
<?before> <? befor XXX> 某字符在 xxx 之前 <?after > <?after XXX> 某字符之后有XXX 对应的取反分别 ...