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$ 的简单路径上的点可 ...
随机推荐
- Django-DRF组件学习-预备知识
1.web开发应用模式 在开发Web应用中,有两种应用模式: 1.1 前后端不分离 所谓的前后端不分离,就是前后端数据都在同一个服务器中,前端的样式以及页面渲染都由后端一次性渲染出来在前端浏览器中展示 ...
- Java——ArrayList源码解析
以下针对JDK 1.8版本中的ArrayList进行分析. 概述 ArrayList基于List接口实现的大小可变的数组.其实现了所有可选的List操作,并且元素允许为任意类型,包括null元 ...
- django学习——通过HttpResponseRedirect 和 reverse实现重定向(转载)
人分类: django 用django开发web应用, 经常会遇到从一个旧的url转向一个新的url,也就是重定向. HttpResponseRedirect:构造函数的第一个参数是必要的 — 用 ...
- 七、Zabbix-模板,应用集,监控项,触发器
本篇内容,将模板,应用集,监控项,触发器放在一起,因为我们建立使用的监控项和触发器,大多数都是对多台机器使用的,很少有一个监控项对应一个主机的情况. 一.模板 1.什么是模板? 个人理解,模板就是模板 ...
- netstat -anop|more 查看网络队列
nux下netstat --timers / -o详解及keepalive相关 第一列,一般有一下几种状态: keepalive - #表示是keepalive的时间计时 on - #表示是重发(re ...
- SQL如何通过当前日期获取上周一日期【转】
--当前时间 select getdate() --当前时间周的起始日期(以周一为例) ,) --上周起始: ,,)) --上上周起始: ,,)) --上上上周起始:s elect ,,))
- 转:mysql datetime类型精确到毫秒、微秒的问题
原文地址:mysql datetime类型精确到毫秒.微秒的问题 mysql里面的datetime类型的精确度是可以到1/ 10 ^ 6 秒的某些客户端(如navicat for mysql)的显示经 ...
- if练习
练习: 1.简述变量命名规范 1.变量名由字母.下划线.数字组成 2.变量名不能以数字开头 3.变量不能使用python中的关键字 4.变量不能使用中文和拼音 5.区分大小写 6.变量名要具有描述性 ...
- 数塔 Easy
在讲述DP算法的时候,一个经典的例子就是数塔问题,它是这样描述的: 有如下所示的数塔,要求从顶层走到底层,若每一步只能走到相邻的结点,则经过的结点的数字之和最大是多少? 已经告诉你了,这是个DP的题 ...
- 手写spring事务框架, 揭秘AOP实现原理。
AOP面向切面编程:主要是通过切面类来提高代码的复用,降低业务代码的耦合性,从而提高开发效率.主要的功能是:日志记录,性能统计,安全控制,事务处理,异常处理等等. AOP实现原理:aop是通过cgli ...