然而这只是 70pts 的部分分,考场上没想到满分怎么做(现在也不会)

code:

#include <cstdio>
#include <string>
#include <stack>
#include <queue>
#include <cstring>
#include <algorithm>
#define N 100009
#define lson ls[x]
#define rson rs[x]
#define inf 4500000
using namespace std;
void setIO(string s) {
string in=s+".in";
string out=s+".out";
freopen(in.c_str(),"r",stdin);
freopen(out.c_str(),"w",stdout);
}
int scc;
int cnt;
int n;
int tot;
int edges;
int A[N*5];
int hd[N*5];
int to[N*30];
int nex[N*30];
int ls[N*5];
int rs[N*5];
int vis[N*5];
int dfn[N*5];
int low[N*5];
int id[N*5];
int In[N*5];
int Ou[N*5];
int tag[N*5];
int X[N],L[N],R[N],con[N];
int is[N*5];
stack<int>S;
queue<int>q;
vector<int>G[N*5];
int newnode() {
return ++tot;
}
void add(int u,int v) {
// printf("%d %d\n",u,v);
nex[++edges]=hd[u];
hd[u]=edges;
to[edges]=v;
}
void update(int &x,int l,int r,int p) {
if(l==r) {
x=p;
return;
}
if(!x) {
x=newnode();
}
int mid=(l+r)>>1;
if(X[p]<=mid) {
update(lson,l,mid,p);
}
else {
update(rson,mid+1,r,p);
}
}
void build(int x) {
if(lson) {
add(x,lson);
build(lson);
}
if(rson) {
add(x,rson);
build(rson);
}
}
void Add(int x,int l,int r,int L,int R,int rt) {
if(!x) {
return;
}
if(l>=L&&r<=R) {
add(rt,x);
return;
}
int mid=(l+r)>>1;
if(L<=mid) {
Add(lson,l,mid,L,R,rt);
}
if(R>mid) {
Add(rson,mid+1,r,L,R,rt);
}
}
void tarjan(int u) {
vis[u]=1;
S.push(u);
low[u]=dfn[u]=++cnt;
for(int i=hd[u];i;i=nex[i]) {
int v=to[i];
if(!vis[v]) {
tarjan(v);
low[u]=min(low[u],low[v]);
}
else if(vis[v]==1) {
low[u]=min(low[u],dfn[v]);
}
}
if(low[u]==dfn[u]) {
++scc;
for(;;) {
int x=S.top();
S.pop();
id[x]=scc;
vis[x]=-1;
if(x==u) {
break;
}
}
}
}
int main() {
// setIO("broadcast");
int i,j;
scanf("%d",&n);
tot=n;
int tp=0;
int root=0;
for(i=1;i<=n;++i) {
scanf("%d%d",&X[i],&con[i]);
L[i]=X[i]-con[i];
R[i]=X[i]+con[i];
A[++tp]=X[i];
A[++tp]=L[i];
A[++tp]=R[i];
}
sort(A+1,A+1+tp);
for(i=1;i<=n;++i) {
X[i]=lower_bound(A+1,A+1+tp,X[i])-A;
L[i]=lower_bound(A+1,A+1+tp,L[i])-A;
R[i]=lower_bound(A+1,A+1+tp,R[i])-A;
}
for(i=1;i<=n;++i) {
update(root,1,inf,i);
}
build(root);
for(i=1;i<=n;++i) {
Add(root,1,inf,L[i],R[i],i);
}
for(i=1;i<=n;++i) {
if(!vis[i]) {
tarjan(i);
}
}
for(i=1;i<=tot;++i) {
for(j=hd[i];j;j=nex[j]) {
int v=to[j];
if(!id[i]||!id[v]) {
continue;
}
if(id[v]!=id[i]) {
++In[id[v]];
++Ou[id[i]];
G[id[i]].push_back(id[v]);
}
}
}
for(i=1;i<=n;++i) {
is[id[i]]=1;
}
for(i=1;i<=scc;++i) {
if(!In[i]) {
q.push(i);
}
}
while(!q.empty()) {
int u=q.front();
q.pop();
for(int i=0;i<G[u].size();++i) {
int v=G[u][i];
--In[v];
tag[v]|=(tag[u]|is[u]);
if(!In[v]) {
q.push(v);
}
}
}
int a1=0;
int a2=0;
for(i=1;i<=scc;++i) {
if(is[i]) {
++a1;
}
}
for(i=1;i<=scc;++i) {
if(!tag[i]&&is[i]) {
++a2;
}
}
printf("%d %d\n",a2,a1);
return 0;
}

  

模拟赛T2 线段树优化建图+tarjan+拓扑排序的更多相关文章

  1. 【bzoj5017】[Snoi2017]炸弹 线段树优化建图+Tarjan+拓扑排序

    题目描述 在一条直线上有 N 个炸弹,每个炸弹的坐标是 Xi,爆炸半径是 Ri,当一个炸弹爆炸时,如果另一个炸弹所在位置 Xj 满足:  Xi−Ri≤Xj≤Xi+Ri,那么,该炸弹也会被引爆.  现在 ...

  2. bzoj5017 炸弹 (线段树优化建图+tarjan+拓扑序dp)

    直接建图边数太多,用线段树优化一下 然后缩点,记下来每个点里有多少个炸弹 然后按拓扑序反向dp一下就行了 #include<bits/stdc++.h> #define pa pair&l ...

  3. BZOJ5017 炸弹(线段树优化建图+Tarjan+拓扑)

    Description 在一条直线上有 N 个炸弹,每个炸弹的坐标是 Xi,爆炸半径是 Ri,当一个炸弹爆炸时,如果另一个炸弹所在位置 Xj 满足:  Xi−Ri≤Xj≤Xi+Ri,那么,该炸弹也会被 ...

  4. 【2019.7.26 NOIP模拟赛 T3】化学反应(reaction)(线段树优化建图+Tarjan缩点+拓扑排序)

    题意转化 考虑我们对于每一对激活关系建一条有向边,则对于每一个点,其答案就是其所能到达的点数. 于是,这个问题就被我们搬到了图上,成了一个图论题. 优化建图 考虑我们每次需要将一个区间向一个区间连边. ...

  5. BZOJ5017 [SNOI2017]炸弹 - 线段树优化建图+Tarjan

    Solution 一个点向一个区间内的所有点连边, 可以用线段树优化建图来优化 : 前置技能传送门 然后就得到一个有向图, 一个联通块内的炸弹可以互相引爆, 所以进行缩点变成$DAG$ 然后拓扑排序. ...

  6. bzoj5017 [Snoi2017]炸弹 (线段树优化建图+)tarjan 缩点+拓扑排序

    题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=5017 题解 这个题目方法挺多的. 线段树优化建图 线段树优化建图的做法应该挺显然的,一个炸弹能 ...

  7. 『炸弹 线段树优化建图 Tarjan』

    炸弹(SNOI2017) Description 在一条直线上有 N 个炸弹,每个炸弹的坐标是 Xi,爆炸半径是 Ri,当一个炸弹爆炸 时,如果另一个炸弹所在位置 Xj 满足: Xi−Ri≤Xj≤Xi ...

  8. Libre OJ 2255 (线段树优化建图+Tarjan缩点+DP)

    题面 传送门 分析 主体思路:若x能引爆y,从x向y连一条有向边,最后的答案就是从x出发能够到达的点的个数 首先我们发现一个炸弹可以波及到的范围一定是坐标轴上的一段连续区间 我们可以用二分查找求出炸弹 ...

  9. 【2019北京集训2】duck 线段树优化建图+tarjan

    题目大意:给你$n$个点,第$i$个点有点权$v_i$.你需要将这$n$个点排成一排,第$i$个点的点权能被累加当且仅当这个点前面存在编号在$[l_i,r_i]$中的点,问你这些点应该如何排列,点权和 ...

随机推荐

  1. .NET CORE编写控制台程序应有的优雅姿势(转载)

    原文地址:https://www.cnblogs.com/zuowj/p/11107243.html 本文所说的编写控制台程序应有的“正确”方法,我把正确二字加上引号,因为没有绝对的正确,因人而异,因 ...

  2. maven集成命令-U -B -P -e -X

    maven -U clean compile install -e -X -Dmaven.test.skip=true 在持续集成服务器上使用怎样的 mvn 命令集成项目,这个问题乍一看答案很显然,不 ...

  3. K8S 如何实现将git代码下拉到指定的容器路径中

    gitRepo 是 kubernetes Volume类型中的一种,gitRepo volume可以实现将git代码下拉到指定的容器路径中. 备注:实现此功能,Pod运行的节点都必需要安装git.换句 ...

  4. HTML禁用Flash文件右键

    在项目中遇到一个需求,由于制作Flash的同事没有做禁用Flash文件右键功能!而Flash文件比较多,一个个改不太现实,于是要求用在网页显示的时候禁用Flash右键功能!未禁用之前! 禁用之前: 禁 ...

  5. SpringCloud-ZUUL网关Cookie被拦截

    在application.properties文件中添加配置(注意后面的值为空) zuul.sensitiveHeaders= org.springframework.cloud.netflix.zu ...

  6. 解决windows server 2008R2自动关机

    原因:找到Windows Licensing Monitoring Service服务 是这服务在作祟,这服务是Windows软件许可状态.任务管理器查看有wlms.exe进程. 使用C:\Windo ...

  7. Shell脚本——求随机数的最值

    写一个脚本,利用RANDOM生成10个随机数,并找出其中的最大值,和最小值: #!/bin/bash # MAX= MIN= ..};do RAN=$RANDOM [ $i -eq ] &&a ...

  8. Maven依赖以及项目创建

    目录: 1. Maven依赖.Eclipse中使用Maven.生命周期 1.1 Maven依赖 1.2 Eclipse中使用Maven 2. 依赖排除.通过Maven整合多个Maven 2.1 依赖排 ...

  9. Spring Security 入门—内存用户验证

    简介 作为 Spring 全家桶组件之一,Spring Security 是一个提供安全机制的组件,它主要解决两个问题: 认证:验证用户名和密码: 授权:对于不同的 URL 权限不一样,只有当认证的用 ...

  10. Lock+Condition实现机制

    前言:大部分多线程同步场景,在功能和性能层面,synchronized可以满足,少部分场景Lock可以满足,dubbo的源码也符合这个比例,需要使用到Condition的场景极少,整个dubbo源码中 ...