BZOJ3073 : [Pa2011]Journeys
用线段树套链表维护所有边,用set维护未访问过的点
然后BFS,每次在线段树上找边,然后在set中查询点
一条边使用之后就没有用了,所以在链表中将它删去
时间复杂度$O((n+m)\log n+m\log^2n)$。
#include<cstdio>
#include<set>
#include<algorithm>
#define N 500010
using namespace std;
int n,m,S,i,c,d,x2,y2,x,z,q[N],h,t,f[N],cnt,pos[N];
struct Edge{int l,r;Edge*nxt;}*g[1048577],pool[9000000],*cur=pool,*p;
set<int>T;set<int>::iterator y,tmp[N];
inline void read(int&a){char c;while(!(((c=getchar())>='0')&&(c<='9')));a=c-'0';while(((c=getchar())>='0')&&(c<='9'))(a*=10)+=c-'0';}
void build(int x,int a,int b){
if(a==b){pos[a]=x;return;}
int mid=(a+b)>>1;
build(x<<1,a,mid),build(x<<1|1,mid+1,b);
}
void ins(int x,int a,int b){
if(c<=a&&b<=d){
p=cur++,p->l=x2,p->r=y2,p->nxt=g[x],g[x]=p;
return;
}
int mid=(a+b)>>1;
if(c<=mid)ins(x<<1,a,mid);
if(d>mid)ins(x<<1|1,mid+1,b);
}
int main(){
read(n),read(m),read(S);
while(m--){
read(c),read(d),read(x2),read(y2),ins(1,1,n);
swap(c,x2),swap(d,y2),ins(1,1,n);
}
build(1,1,n),q[h=t=1]=S;
for(i=1;i<=n+1;i++)if(i!=S)T.insert(i);
while(h<=t)for(z=f[x=q[h++]]+1,x=pos[x];x;g[x]=NULL,x>>=1)for(p=g[x];p;p=p->nxt){
for(cnt=0,y=T.lower_bound(p->l);*y<=p->r;y++)f[q[++t]=*y]=z,tmp[++cnt]=y;
while(cnt)T.erase(tmp[cnt--]);
}
for(i=1;i<=n;i++)printf("%d\n",f[i]);
return 0;
}
BZOJ3073 : [Pa2011]Journeys的更多相关文章
- bzoj3073: [Pa2011]Journeys 线段树优化建图
		
bzoj3073: [Pa2011]Journeys 链接 BZOJ 思路 区间和区间连边.如何线段树优化建图. 和单点连区间类似的,我们新建一个点,区间->新点->区间. 又转化成了单点 ...
 - BZOJ3073: [Pa2011]Journeys(线段树优化建图  Dijkstra)
		
题意 \(n\)个点的无向图,构造\(m\)次边,求\(p\)到任意点的最短路. 每次给出\(a, b, c, d\) 对于任意\((x_{a \leqslant x \leqslant b}, y_ ...
 - BZOJ3073 [Pa2011]Journeys[最短路—线段树优化建边]
		
新技能get✔. 线段树优化建边主要是针对一类连续区间和连续区间之间建边的题,建边非常的优秀.. 这题中,每次要求$[l1,r1]$每一点向$[l2,r2]$每一点建无向边,然后单元最短路. 暴力建边 ...
 - 【BZOJ3073】[Pa2011]Journeys 线段树+堆优化Dijkstra
		
[BZOJ3073][Pa2011]Journeys Description Seter建造了一个很大的星球,他准备建造N个国家和无数双向道路.N个国家很快建造好了,用1..N编号,但是他发现道路实在 ...
 - bzoj 3073: [Pa2011]Journeys  -- 线段树优化最短路
		
3073: [Pa2011]Journeys Time Limit: 20 Sec Memory Limit: 512 MB Description Seter建造了一个很大的星球,他准备建 ...
 - 【bzoj3073】[Pa2011]Journeys  线段树优化建图+堆优化Dijkstra
		
题目描述 Seter建造了一个很大的星球,他准备建造N个国家和无数双向道路.N个国家很快建造好了,用1..N编号,但是他发现道路实在太多了,他要一条条建简直是不可能的!于是他以如下方式建造道路:(a, ...
 - bzoj 3073 [Pa2011]Journeys ——线段树优化连边
		
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3073 建两棵线段树,一棵孩子向父亲连边,是走出去的:一棵父亲向孩子连边,是走进来的. 注意第 ...
 - BZOJ 3073: [Pa2011]Journeys Dijkstra+线段树优化建图
		
复习一下线段树优化建图:1.两颗线段树的叶子节点的编号是公用的. 2.每次连边是要建两个虚拟节点 $p1,p2$ 并在 $p1,p2$ 之间连边. #include <bits/stdc++.h ...
 - CF786B Legacy(线段树优化建边)
		
模板题CF786B Legacy 先说算法 如果需要有n个点需要建图 给m个需要建边的信息,从单点(或区间内所有点)向一区间所有点连边 如果暴力建图复杂度\(mn^2\) 以单点连向区间为例,在n个点 ...
 
随机推荐
- Unity3D脚印6——模型动画
			
原地址:http://www.cnblogs.com/ybgame/archive/2013/02/21/2920009.html 如何导入一个模型,导入的模型在unity3d的project面板中是 ...
 - IOS项目删除Git
			
默认创建工程会在MAC上面创建Git版本管理, 但是呢, 我现在想上传到svn服务器进行管理, 但是已经有个git 好像上传不了 只有把Git删了才能继续. 连问带查, 终于找到解决方案 把 .git ...
 - [BZOJ2820]YY的GCD
			
[BZOJ2820]YY的GCD 试题描述 神犇YY虐完数论后给傻×kAc出了一题给定N, M,求1<=x<=N, 1<=y<=M且gcd(x, y)为质数的(x, y)有多少 ...
 - 异常:The absolute uri: http://www.springframework.org/security/tags cannot be resolved in either web.xml or the jar files deployed with this application
			
The absolute uri: http://www.springframework.org/security/tags cannot be resolved in either web.xml ...
 - python - PyQuery
			
偶尔的机会,知道这么个扩展,手贱翻了下文档,发现似乎挺有意思,遂记录一二. what: 这是一个python版本的jquery,而且是后端执行的,至少官方是这么说的: pyquery allows y ...
 - WAF绕过神器 (过安全狗、智创SQL注入)
			
WAF绕过神器 (过安全狗.智创SQL注入) 发布时间:-- :10文章来源:网络文章作者:panni007 点击次数: 次 分享到: QQ空间 QQ微博 新浪微博 开心网 人人网 摘要:起因: by ...
 - linux下统计当前目录下文件个数
			
ls | wc -l 转自:http://bbs.csdn.net/topics/60387132
 - 全面解释StringBuilder、StringBuffer和String的关系
			
1. String 类 String的值是不可变的,这就导致每次对String的操作都会生成新的String对象,不仅效率低下,而且大量浪费有限的内存空间. String a = " ...
 - abstract class和interface的区别
			
1. 引言 2. 概念引入 ●什么是接口? 接口是包含一组虚方法的抽象类型,其中每一种方法都有其名称.参数和返回值.接口方法不能包含任何实现,CLR允许接口可以包含事件.属性.索引 器.静态方法.静态 ...
 - eclipse内存设置,tomcat内存设置,查看内存大小
			
首先可以通过java/jdk/bin下的java visualVM查看eclipse的内存大小和tomcat的内存大小,主要看堆,PermGen两个大小 如图: 多数情况下,eclipse抛出内存溢出 ...