线段树优化建图。 建立两棵线段树,其上点的点权分别表示“到达这个区间内所有点的最小花费”和“到达这个区间内任意一个点的最小花费”。

对于第一种路直接加边即可 对于第二种路,添加从v到第一棵线段树对应区间中的点的边 对于第三种路,添加从第二棵线段树对应区间中的点到v的边。

可以给每个区间设一个序号,将对应区间与对应点连边就行了。之前一直没有YY出来这个,一直放的。。。

#include <iostream>
#include <queue>
#include <cstdio>
#include <cstring>
using namespace std;
const int N=300005;
struct Edge{int to,nxt,val;}e[2000005];
int head[N],ecnt,cnt,ql,qr,opt,n,q,S,rt1,rt2;
void add(int bg,int ed,int val) {e[++ecnt].nxt=head[bg];e[ecnt].to=ed;e[ecnt].val=val;head[bg]=ecnt;}
int ls[N],rs[N];
void build1(int &k,int l,int r) {
if(l<r) {
k=++cnt;int mid=l+r>>1;
build1(ls[k],l,mid);build1(rs[k],mid+1,r);
add(k,ls[k],0);add(k,rs[k],0);
}
else k=l;
}
void build2(int &k,int l,int r) {
if(l<r) {
k=++cnt;int mid=l+r>>1;
build2(ls[k],l,mid);build2(rs[k],mid+1,r);
add(ls[k],k,0);add(rs[k],k,0);
}
else k=l;
}
void update(int k,int l,int r,int u,int val) {
if(ql<=l&&r<=qr) {
opt==2?add(u,k,val):add(k,u,val);return;
}
int mid=l+r>>1;
if(ql<=mid) update(ls[k],l,mid,u,val);
if(mid<qr) update(rs[k],mid+1,r,u,val);
}
long long dis[N];
struct Node {
int id;long long dis;
bool operator < (const Node &rhs) const {return dis>rhs.dis;}
};
void dij() {
priority_queue<Node>q;
q.push({S,0});
memset(dis,0x3f,sizeof dis);
dis[S]=0;
while(!q.empty()) {
Node u=q.top();q.pop();
if(u.dis!=dis[u.id]) continue;
for(int i=head[u.id];i;i=e[i].nxt) {
int v=e[i].to;
if(dis[u.id]+e[i].val<dis[v]) {
dis[v]=dis[u.id]+e[i].val;q.push({v,dis[v]});
}
}
}
}
int main() {
scanf("%d%d%d",&n,&q,&S);
cnt=n;
build1(rt1,1,n);
build2(rt2,1,n);
int u,v,val;
while(q--) {
scanf("%d",&opt);
if(opt==1) {
scanf("%d%d%d",&u,&v,&val);add(u,v,val);
}
else {
scanf("%d%d%d%d",&u,&ql,&qr,&val);
update(opt==3?rt2:rt1,1,n,u,val);
}
}
dij();
for(int i=1;i<=n;i++)
printf("%lld ",(dis[i]==0x3f3f3f3f3f3f3f3f)?-1:dis[i]);
}

[CodeForces]786B Legacy的更多相关文章

  1. CodeForces 786B Legacy(线段树优化建图+最短路)

    [题目链接] http://codeforces.com/problemset/problem/786/B [题目大意] 给出一些星球,现在有一些传送枪,可以从一个星球到另一个星球, 从一个星球到另一 ...

  2. Codeforces 786B Legacy(线段树优化建图)

    题目链接  Legacy 首先对于输入的$n$,建立一棵线段树. 显然线段树有大概$2n$个结点,每个节点对应一段区间 我们把这$2n$个结点加入我们的无向图中,一起跑最短路. 具体连边方案: 我们把 ...

  3. Codeforces.786B.Legacy(线段树优化建图 最短路Dijkstra)

    题目链接 \(Description\) 有\(n\)个点.你有\(Q\)种项目可以选择(边都是有向边,每次给定\(t,u,v/lr,w\)): t==1,建一条\(u\to v\)的边,花费\(w\ ...

  4. CodeForces - 786B Legacy (线段树+DIjkstra+思维)

    题意:给N个点和Q条选项,有三种类型的选项:1.从u到v花费w修建一条路:2.从u到下标区间为[L,R]的点花费w修建一条路; 3.从下标区间为[L,R]的点到u花费w修建一条路. 然后求起点s到其余 ...

  5. Codeforces 786B. Legacy 线段树+spfa

    题目大意: 给定一个\(n\)的点的图.求\(s\)到所有点的最短路 边的给定方式有三种: \(u \to v\) \(u \to [l,r]\) \([l,r] \to v\) 设\(q\)为给定边 ...

  6. Codeforces 787D. Legacy 线段树建模+最短路

    D. Legacy time limit per test:2 seconds memory limit per test:256 megabytes input:standard input out ...

  7. [Codeforces 787D] Legacy

    [题目链接] https://codeforces.com/contest/787/problem/D [算法] 线段树优化建边 ,  然后用Dijkstra算法求单源最短路 时间复杂度 : O((N ...

  8. codeforces 787D - Legacy 线段树优化建图,最短路

    题意: 有n个点,q个询问, 每次询问有一种操作. 操作1:u→[l,r](即u到l,l+1,l+2,...,r距离均为w)的距离为w: 操作2:[l,r]→u的距离为w 操作3:u到v的距离为w 最 ...

  9. Codeforces 787D Legacy 线段树 最短路

    题意: 有\(n(1 \leq n \leq 10^5)\)个点,\(q(1 \leq q \leq 10^5)\)条路和起点\(s\) 路有三种类型: 从点\(v\)到点\(u\)需要花费\(w\) ...

随机推荐

  1. 【ACM】hdu_1095_A+BVII_201307261740

    A+B for Input-Output Practice (VII)Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/327 ...

  2. STM32的IO配置点灯

    1.led.c的详细的代码: /*----------------------------------------------------------*/ #include "led.h&q ...

  3. 【c语言】数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字

    题目:数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字. 比如输入一个长度为9的数组{1,2.3.2,2.2.5,4.2}, 因为数组中数字2出现了5次,超过数组的长度的一半,因此输出2 ...

  4. 浅析hybrid模式下地支付宝钱包和微信

    watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvd2VuY2hhbzEyNg==/font/5a6L5L2T/fontsize/400/fill/I0JBQk ...

  5. Java深入 - Filter过滤器

    Java的1.3開始,对servlet2.3规范中增加了过滤器的支持.过滤器可以让我们对目标资源的请求和响应进行截取. 一些filter的特性: 1. Filter是Servlet规范的规定,须要Se ...

  6. DevExpress14.1.2 xe XE6 高速安装

    之前在在网上下载的DevExpress14.1.2 xe-XE6都是一个个包文件.须要一个个去查找编译安装,并且须要有一定的顺序要求. 所下面载了好久了都没有安装. 近期在网上找了个旧版的安装方法.以 ...

  7. ijkplayer详解AAA

    https://www.jianshu.com/p/c5d972ab0309 https://www.android-arsenal.com/details/1/530 https://stackov ...

  8. 样条函数(spline function)—— 分段多项式函数(piecewise polynomial function)

    1. 分段多项式函数 样条函数是某种意义上的分段函数. Spline (mathematics) - Wikipedia 最简单的样条函数是一种分段多项式函数(piecewise polynomial ...

  9. 基于Websocket的火拼俄罗斯(基础)

    传统的HTTP请求是由浏览器发起,然后呢服务端接收到请求之后呢返回一个数据.那么这样一次来回之后呢请求就断了.但是WebSocket它不一样,它同样是由浏览器去发起一个请求但是这个请求是一个WebSo ...

  10. 南海区行政审批管理系统接口规范v0.3(规划) 3.业务办理API 3.1.businessAuditById【业务办理】

    {"c_accept":"Q2015112400002","c_operators":"gz99","v_op ...