题面:786B - Legacy

代码:

 #include<cstdio>
#include<cstring>
#include<iostream>
#include<queue>
#define ll long long
using namespace std;
inline ll rd(){
ll x=,f=;char c=getchar();
while(c<''||c>''){if(c=='-')f=-; c=getchar();}
while(c>=''&&c<=''){x=x*+c-''; c=getchar();}
return f*x;
}
const int maxn=(1e5)+,maxq=maxn;
const ll inf=1ll<<;
int N,S,Q,o,v,u,ql,qr,num_edge=,edge_head[maxn*];
int tr[maxn*][],cnt;
ll w,Dis[maxn*];
bool vis[maxn*];
struct Num_{
int id;ll dis;
bool operator < (const Num_&a) const{
return a.dis<dis;
}
}e;
priority_queue<Num_>pri;
struct Edge{ int to,nx; ll dis; }edge[maxn*];
inline void Add_edge(int from,int to,int dis){
edge[++num_edge].nx=edge_head[from];
edge[num_edge].to=to;
edge[num_edge].dis=dis;
edge_head[from]=num_edge;
return;
}
void Build(int x,int l,int r){
if(l==r){
tr[x][]=tr[x][]=l;
return;
}
int m=(l+r)>>;
tr[x][]=++cnt; tr[x][]=++cnt;
Build(x<<,l,m); Build(x<<|,m+,r);
Add_edge(tr[x][],tr[x<<][],);
Add_edge(tr[x][],tr[x<<|][],);
Add_edge(tr[x<<][],tr[x][],);
Add_edge(tr[x<<|][],tr[x][],);
return;
}
void Update(int x,int l,int r,int ql,int qr,int u,int val,int op){
if(ql<=l&&r<=qr){
if(op==) Add_edge(u,tr[x][],val);
else Add_edge(tr[x][],u,val);
return;
}
int m=(l+r)>>;
if(ql<=m)Update(x<<,l,m,ql,qr,u,val,op);
if(qr>m)Update(x<<|,m+,r,ql,qr,u,val,op);
return;
}
inline void Dijkstra(int s){
for(int i=;i<=cnt;i++)Dis[i]=inf;
Dis[s]=;
e.id=s;e.dis=;
pri.push(e);
while(!pri.empty()){
int x=(pri.top()).id;
pri.pop();
if(vis[x])continue;
vis[x]=;
for(int i=edge_head[x];i;i=edge[i].nx){
int y=edge[i].to;
if(Dis[x]+edge[i].dis<Dis[y]){
Dis[y]=Dis[x]+edge[i].dis;
e.id=y;e.dis=Dis[y];
pri.push(e);
}
}
}
return;
}
int main(){
N=rd();Q=rd();S=rd();
cnt=N;
Build(,,N);
while(Q--){
o=rd();
if(o==){
v=rd();u=rd();w=rd();
Add_edge(v,u,w);
}
else {
v=rd();ql=rd();qr=rd();w=rd();
if(o==)
Update(,,N,ql,qr,v,w,);
else//o==3
Update(,,N,ql,qr,v,w,);
}
}
Dijkstra(S);
for(int i=;i<=N;i++)
if(Dis[i]!=inf)printf("%lld ",Dis[i]);
else printf("-1 ");
return ;
}

邻接表建图版

 #include<cstdio>
#include<cstring>
#include<iostream>
#include<queue>
#define make(a,b) (make_pair(a,b))
#define ll long long
using namespace std;
inline ll rd(){
ll x=,f=;char c=getchar();
while(c<''||c>''){if(c=='-')f=-; c=getchar();}
while(c>=''&&c<=''){x=x*+c-''; c=getchar();}
return f*x;
}
const int maxn=(1e5)+,maxq=maxn;
const ll inf=1ll<<;
int N,Q,S,trIn[maxn<<],trOut[maxn<<];
int u,v,ql,qr,o,cnt;
bool vis[maxn<<];
vector<pair<int,ll> >edge[maxn<<];//to,val
ll w,Dis[maxn<<];
struct Num_{
ll dis;
int id;
bool operator < (const Num_&a) const {
return a.dis<dis;
}
}b;
priority_queue<Num_>pri;
void Build(int x,int l,int r){
if(l==r){
trIn[x]=l;
trOut[x]=l;
return;
}
int mid=(l+r)>>;
trIn[x]=++cnt;trOut[x]=++cnt;
Build(x<<,l,mid);Build(x<<|,mid+,r);
edge[trIn[x]].push_back(make(trIn[x<<],));
edge[trIn[x]].push_back(make(trIn[x<<|],));
edge[trOut[x<<]].push_back(make(trOut[x],));
edge[trOut[x<<|]].push_back(make(trOut[x],));
return;
}
void Update(int x,int l,int r,int ql,int qr,int u,int val,int o){
if(ql<=l&&r<=qr){
if(o==)//In
edge[u].push_back(make(trIn[x],val));
else//Out
edge[trOut[x]].push_back(make(u,val));
return;
}
int mid=(l+r)>>;
if(ql<=mid)Update(x<<,l,mid,ql,qr,u,val,o);
if(qr>mid)Update(x<<|,mid+,r,ql,qr,u,val,o);
return;
}
inline void Dijkstra(int s){
for(int i=;i<=cnt;i++)Dis[i]=inf;
Dis[s]=;
b.dis=;b.id=s;
pri.push(b);
while(!pri.empty()){
int x=(pri.top()).id;
pri.pop();
if(vis[x])continue;
vis[x]=;
int toi=edge[x].size();
for(int i=;i<toi;i++){
int y=edge[x][i].first;
if(Dis[y]>Dis[x]+edge[x][i].second){
Dis[y]=Dis[x]+edge[x][i].second;
b.id=y;b.dis=Dis[y];
pri.push(b);
}
}
}
return;
}
int main(){
N=rd();Q=rd();S=rd();
cnt=N;
Build(,,N);
while(Q--){
o=rd();
if(o==){
v=rd();u=rd();w=rd();
edge[v].push_back(make(u,w));
}
else if(o==){
v=rd();ql=rd();
qr=rd();w=rd();
Update(,,N,ql,qr,v,w,);
}
else {//o==3
v=rd();ql=rd();
qr=rd();w=rd();
Update(,,N,ql,qr,v,w,);
}
}
Dijkstra(S);
for(int i=;i<=N;i++){
if(Dis[i]!=inf) printf("%lld ",Dis[i]);
else printf("-1 ");
}
return ;
}

Vector建图版


By:AlenaNuna

线段树优化建图 || CF786B Legacy的更多相关文章

  1. CF786B Legacy 线段树优化建图 + spfa

    CodeForces 786B Rick和他的同事们做出了一种新的带放射性的婴儿食品(???根据图片和原文的确如此...),与此同时很多坏人正追赶着他们.因此Rick想在坏人们捉到他之前把他的遗产留给 ...

  2. G. 神圣的 F2 连接着我们 线段树优化建图+最短路

    这个题目和之前写的一个线段树优化建图是一样的. B - Legacy CodeForces - 787D 线段树优化建图+dij最短路 基本套路 之前这个题目可以相当于一个模板,直接套用就可以了. 不 ...

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

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

  4. 【BZOJ3681】Arietta 树链剖分+可持久化线段树优化建图+网络流

    [BZOJ3681]Arietta Description Arietta 的命运与她的妹妹不同,在她的妹妹已经走进学院的时候,她仍然留在山村中.但是她从未停止过和恋人 Velding 的书信往来.一 ...

  5. 【ARC069F】Flags 2-sat+线段树优化建图+二分

    Description ​ 数轴上有 n 个旗子,第 ii 个可以插在坐标 xi或者 yi,最大化两两旗子之间的最小距离. Input ​ 第一行一个整数 N. ​ 接下来 N 行每行两个整数 xi, ...

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

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

  7. 【bzoj4699】树上的最短路(树剖+线段树优化建图)

    题意 给你一棵 $n$ 个点 $n-1$ 条边的树,每条边有一个通过时间.此外有 $m$ 个传送条件 $(x_1,y_1,x_2,y_2,c)$,表示从 $x_1$ 到 $x_2$ 的简单路径上的点可 ...

  8. 【BZOJ4276】[ONTAK2015]Bajtman i Okrągły Robin 线段树优化建图+费用流

    [BZOJ4276][ONTAK2015]Bajtman i Okrągły Robin Description 有n个强盗,其中第i个强盗会在[a[i],a[i]+1],[a[i]+1,a[i]+2 ...

  9. 【bzoj3073】[Pa2011]Journeys 线段树优化建图+堆优化Dijkstra

    题目描述 Seter建造了一个很大的星球,他准备建造N个国家和无数双向道路.N个国家很快建造好了,用1..N编号,但是他发现道路实在太多了,他要一条条建简直是不可能的!于是他以如下方式建造道路:(a, ...

随机推荐

  1. [flask-sqlalchemy]倒序查询结果

    按创建时间倒序查询测试用例 >>> a= TestCase.query.order_by(TestCase.create_time.desc()).first() >>& ...

  2. Python学习-------变量和简单的数据类型(String)

    1.变量命名和使用 变量命名规则:a.变量名只能包含(字母    数字   下划线),且变量不能以数字开头,例如:变量 s_1(正确),变量1_s(错误) b.变量名不能包含空格,可以使用下划线来间隔 ...

  3. 关于struts2防止表单重复提交

    struts2防表单重复提交有两种方式. 其一是action的重定向,跳转时设置type为从一个action跳转到另一个action或者另一个页面, 使用户提交后,所停留的位置,不是当前处理数据的Ac ...

  4. poatman接口测试--初试

    接到测试任务,对两个商品接口,进行接口测试 测试工具:postman 域名:rap2查找的或询问开发, 接口的参数规则:参考rap2的备注 开发没有添加详细说明的,让开发补充说明规则,及定义的返回状态 ...

  5. java之 Mybatis框架

    1.三层框架: 表现层: 是用于展示数据 业务层: 是处理业务需求 持久层: 是和数据库交互 注:MyBatis在持久层 2.JDBC操作数据库 public static void main(Str ...

  6. json,异步加载,时间线

    JSON是一种传输数据的格式 JSON.stringify(obj);  obj--string JSON.parse(str);   string-->obj      

  7. 【GNN】图神经网络小结

    图神经网络小结 图神经网络小结 图神经网络分类 GCN: 由谱方法到空域方法 GCN概述 GCN的输出机制 GCN的不同方法 基于谱方法的GCN 初始 切比雪夫K阶截断: ChebNet 一阶Cheb ...

  8. Centos7搭建Open-ldap

    OpenLDAP是轻型目录访问协议(Lightweight Directory Access Protocol,LDAP)的自由和开源的实现,可用于实现统一认证 一.安装环境 安装方式:yum 系统: ...

  9. [Python3] 026 常用模块 calendar

    目录 calendar 1. calendar.calendar(year, w, l, c, m) 2. calendar.prcal(year, w, l, c, m) 3. calendar.m ...

  10. Codeforces Round #590 (Div. 3)(e、f待补

    https://codeforces.com/contest/1234/problem/A A. Equalize Prices Again #include<bits/stdc++.h> ...