CF786B Legacy 线段树优化建图 + spfa
Rick和他的同事们做出了一种新的带放射性的婴儿食品(???根据图片和原文的确如此...),与此同时很多坏人正追赶着他们。因此Rick想在坏人们捉到他之前把他的遗产留给Morty。
在宇宙中一共有n个星球标号为1到n。Rick现在身处于标号为s的星球(地球)但是他不知道Morty在哪里。众所周知,Rick有一个传送枪,他用这把枪可以制造出一个从他所在的星球通往其他星球(也包括自己所在的星球)的单行道路。但是由于他还在用免费版,因此这把枪的使用是有限制的。
默认情况下他不能用这把枪开启任何传送门。在网络上有q个售卖这些传送枪的使用方案。每一次你想要实施这个方案时你都可以购买它,但是每次购买后只能使用一次。每个方案的购买次数都是无限的。
网络上一共有三种方案可供购买: 1.开启一扇从星球v到星球u的传送门; 2.开启一扇从星球v到标号在[l,r]区间范围内任何一个星球的传送门。(即这扇传送门可以从一个星球出发通往多个星球) 3.开启一扇从标号在[l,r]区间范围内任何一个星球到星球v的传送门。(即这扇传送门可以从多个星球出发到达同一个星球)
Rick并不知道Morty在哪儿,但是Unity将要通知他Morty的具体位置,并且他想要赶快找到通往所有星球的道路各一条并立刻出发。因此对于每一个星球(包括地球本身)他想要知道从地球到那个星球所需的最小钱数。
输入数据: 输入数据的第一行包括3个整数n,q和s(1<=n,q<=10^5,1<=s<=n)分别表示星球的数目,可供购买的方案数目以及地球的标号。
接下来的q行表示q种方案。 1.输入1 v u w表示第一种方案,其中v,u意思同上,w表示此方案价格。 2.输入2 v l r w表示第二种方案,其中v,l,r意思同上,w表示此方案价格。 2.输入3 v l r w表示第三种方案,其中v,l,r意思同上,w表示此方案价格。 (1<=v,u,l,r<=n,1<=w<=10^9)
输出格式: 输出一行用空格隔开的n个整数分别表示从地球到第i个星球所需的最小钱数。
说明: 在第一组测试样例里,Rick可以先购买第4个方案再购买第2个方案从而到达标号为2的星球.
题解:
线段树优化建图模板题
建立两颗线段树,这两颗线段树共用编号相同的叶子节点
在线段树对应区间上连一连就好了
#include<bits/stdc++.h>
#define setIO(s) freopen(s".in","r",stdin)
#define maxn 4000000
#define inf 100000000000000
#define lson t[now].ls
#define rson t[now].rs
#define ll long long
using namespace std;
struct Data {
int ls,rs,l,r;
}t[maxn];
queue<int>Q;
int n,q,s,rtin,rtout,cnt,edges;
int hd[maxn],to[maxn],nex[maxn];
ll val[maxn],dis[maxn];
int inq[maxn];
void addedge(int u,int v,ll c) {
nex[++edges]=hd[u],hd[u]=edges,to[edges]=v,val[edges]=c;
}
int newnode() {
return ++cnt;
}
namespace In {
void build(int l,int r,int &now) {
if(l==r) {
now=l;
return;
}
int mid=(l+r)>>1;
now=newnode(), t[now].l=l, t[now].r=r;
build(l,mid,lson), addedge(now,lson,0);
if(r>mid) build(mid+1,r,rson), addedge(now,rson,0);
}
void Add(int l,int r,int now,int L,int R,int c) {
if(l>=L&&r<=R) {
addedge(c,now,0);
return;
}
int mid=(l+r)>>1;
if(L<=mid) Add(l,mid,lson,L,R,c);
if(R>mid) Add(mid+1,r,rson,L,R,c);
}
};
namespace Out {
void build(int l,int r,int &now) {
if(l==r) {
now=l;
return;
}
int mid=(l+r)>>1;
now=newnode(), t[now].l=l, t[now].r=r;
build(l,mid,lson), addedge(lson,now,0);
if(r>mid) build(mid+1,r,rson), addedge(rson,now,0);
}
void Add(int l,int r,int now,int L,int R,int c) {
if(l>=L&&r<=R) {
addedge(now,c,0);
return;
}
int mid=(l+r)>>1;
if(L<=mid) Add(l,mid,lson,L,R,c);
if(R>mid) Add(mid+1,r,rson,L,R,c);
}
};
void Addedge(int l1,int r1,int l2,int r2,ll delta) {
int p1=newnode(), p2=newnode();
addedge(p1,p2,delta);
Out::Add(1,n,rtout,l1,r1,p1);
In::Add(1,n,rtin,l2,r2,p2);
}
void spfa() {
for(int i=0;i<maxn;++i) dis[i]=inf;
Q.push(s), dis[s]=0,inq[s]=1;
while(!Q.empty()) {
int u=Q.front(); Q.pop();
inq[u]=0;
for(int i=hd[u];i;i=nex[i]) {
int v=to[i];
if(dis[v] > dis[u]+val[i]) {
dis[v]=dis[u]+val[i];
if(!inq[v])
Q.push(v), inq[v]=1;
}
}
}
}
int main() {
// setIO("input");
scanf("%d%d%d",&n,&q,&s);
cnt=n, In::build(1,n,rtin), Out::build(1,n,rtout);
for(int i=1;i<=q;++i) {
int opt,l1,r1,l2,r2,w;
scanf("%d",&opt);
if(opt==1) scanf("%d%d",&l1,&l2),r1=l1,r2=l2;
if(opt==2) scanf("%d%d%d",&l1,&l2,&r2),r1=l1;
if(opt==3) scanf("%d%d%d",&l2,&l1,&r1),r2=l2;
scanf("%d",&w);
Addedge(l1,r1,l2,r2,1ll*w);
}
spfa();
for(int i=1;i<=n;++i) printf("%I64d ",dis[i]==inf?-1:dis[i]);
return 0;
}
CF786B Legacy 线段树优化建图 + spfa的更多相关文章
- Codeforces.786B.Legacy(线段树优化建图 最短路Dijkstra)
题目链接 \(Description\) 有\(n\)个点.你有\(Q\)种项目可以选择(边都是有向边,每次给定\(t,u,v/lr,w\)): t==1,建一条\(u\to v\)的边,花费\(w\ ...
- BZOJ_4276_[ONTAK2015]Bajtman i Okrągły Robin_线段树优化建图+最大费用最大流
BZOJ_4276_[ONTAK2015]Bajtman i Okrągły Robin_线段树优化建图+最大费用最大流 Description 有n个强盗,其中第i个强盗会在[a[i],a[i]+1 ...
- CF786B Legacy 线段树优化建图
问题描述 CF786B LG-CF786B 题解 线段树优化建图 线段树的一个区间结点代表 \([l,r]\) 区间点. 然后建立区间点的时候就在线段树上建边,有效减少点的个数,从而提高时空效率. 优 ...
- G. 神圣的 F2 连接着我们 线段树优化建图+最短路
这个题目和之前写的一个线段树优化建图是一样的. B - Legacy CodeForces - 787D 线段树优化建图+dij最短路 基本套路 之前这个题目可以相当于一个模板,直接套用就可以了. 不 ...
- BZOJ5017 [SNOI2017]炸弹 - 线段树优化建图+Tarjan
Solution 一个点向一个区间内的所有点连边, 可以用线段树优化建图来优化 : 前置技能传送门 然后就得到一个有向图, 一个联通块内的炸弹可以互相引爆, 所以进行缩点变成$DAG$ 然后拓扑排序. ...
- 【BZOJ3681】Arietta 树链剖分+可持久化线段树优化建图+网络流
[BZOJ3681]Arietta Description Arietta 的命运与她的妹妹不同,在她的妹妹已经走进学院的时候,她仍然留在山村中.但是她从未停止过和恋人 Velding 的书信往来.一 ...
- 【ARC069F】Flags 2-sat+线段树优化建图+二分
Description 数轴上有 n 个旗子,第 ii 个可以插在坐标 xi或者 yi,最大化两两旗子之间的最小距离. Input 第一行一个整数 N. 接下来 N 行每行两个整数 xi, ...
- 【bzoj5017】[Snoi2017]炸弹 线段树优化建图+Tarjan+拓扑排序
题目描述 在一条直线上有 N 个炸弹,每个炸弹的坐标是 Xi,爆炸半径是 Ri,当一个炸弹爆炸时,如果另一个炸弹所在位置 Xj 满足: Xi−Ri≤Xj≤Xi+Ri,那么,该炸弹也会被引爆. 现在 ...
- 【bzoj4699】树上的最短路(树剖+线段树优化建图)
题意 给你一棵 $n$ 个点 $n-1$ 条边的树,每条边有一个通过时间.此外有 $m$ 个传送条件 $(x_1,y_1,x_2,y_2,c)$,表示从 $x_1$ 到 $x_2$ 的简单路径上的点可 ...
随机推荐
- jenkins自动化测试Email Extension邮件模板 及可用参数TEST_COUNTS ,FAILED_TESTS详细说明
先列出模板内容: <!DOCTYPE html><html> <head> <meta charset="UTF-8"> <t ...
- Python_ONLINE_习题集_02 函数封装
2.1 封装函数实现如下要求 例如:输入2,5 则求:2 + 22+222 + 2222+22222的和 参考答案: https://www.bilibili.com/read/cv4185619 d ...
- oracle系统视图SQL语句整理
-- DBA/ALL/USER/V_$/GV_$/SESSION/INDEX开头的绝大部分都是视图 -- DBA_TABLES意为DBA拥有的或可以访问的所有的关系表. -- ALL_TABLES意为 ...
- mongodb启动报错,child process failed, exited with error number 1
error: child process failed, exited with error number 1 第一次安装mongodb,随后启动一般不会出现上面的错误,出现这种错误的原因一般是mon ...
- 计算机体系结构总结_Pipeline
Textbook:<计算机组成与设计——硬件/软件接口> HI<计算机体系结构——量化研究方法> QR 在前面一节里我们有了一块简单的RISC CPU,包括 ...
- 完整ASP.Net Excel导入
//把EXCEL文件上传到服务器并返回文件路径 private String typename(FileUpload fileloads) { str ...
- luogu P5331 [SNOI2019]通信
传送门 有匹配次数限制,求最小代价,这显然是个费用流的模型.每个点暴力和前面的点连匹配边,边数是\(n^2\)的. 然后发现可以转化成一个set,每次加入一个点,然后入点对set里面的出点连边.这个s ...
- Timer的利用
package 第十一章; import java.util.*; import java.util.TimerTask; public class TimerTest { /** * @param ...
- 【问题解决方案】Centos操作文件vim-No write since last change (add ! to override)
参考链接 CSDN:Centos 7 操作文件No write since last change (add ! to override) 问题描述: :q或者:wq退出失败,显示如No write ...
- js放大镜特效
在平时网上商城购物时,我们能够通过放大镜效果来使我们看图片能够更加的清楚,今天我就来给大家分享一下我学习的放大镜特效 下图是原图的样子 ...