CodeForces 786B Legacy(线段树优化建图+最短路)
【题目链接】 http://codeforces.com/problemset/problem/786/B
【题目大意】
给出一些星球,现在有一些传送枪,可以从一个星球到另一个星球,
从一个星球到另一些星球,或者从一些星球到某个星球,每种传送枪使用一次要花费不同的价格
地球是其中一个星球,问从地球到其它星球的最少花费是多少
【题解】
因为一个星球到一些星球和一些星球到某个星球是以区间形式给出的,
所以我们可以用线段树建图优化,对点进行压缩,
建立两颗线段树表示有向线段左端和右端的合并情况,之后在优化后的图上跑最短路即可。
【代码】
#include <cstdio>
#include <algorithm>
#include <utility>
#include <vector>
#include <queue>
using namespace std;
const int N=100010;
const int V=N*5;
int n,m,s;
vector<pair<int,int> >G[V];
void addedge(int u,int v,int c){G[u].push_back(make_pair(v,c));}
int id[2][N<<2],idx;
void build(int x,int l,int r,int k){
id[k][x]=++idx;
if(l==r){
if(k==0)addedge(id[k][x],l,0);
else addedge(l,id[k][x],0);
return;
}
int mid=(l+r)>>1;
build(x<<1,l,mid,k);
build(x<<1|1,mid+1,r,k);
if(k==0){
addedge(id[k][x],id[k][x<<1],0);
addedge(id[k][x],id[k][x<<1|1],0);
}else{
addedge(id[k][x<<1],id[k][x],0);
addedge(id[k][x<<1|1],id[k][x],0);
}
}
vector<int> vs;
void get(int x,int l,int r,int L,int R,int k){
if(L<=l&&r<=R){
vs.push_back(id[k][x]);
return;
}
int mid=(l+r)>>1;
if(L<=mid)get(x<<1,l,mid,L,R,k);
if(R>mid)get(x<<1|1,mid+1,r,L,R,k);
}
typedef long long LL;
const LL LLINF=0x3f3f3f3f3f3f3f3fLL;
LL dis[V]; bool vis[V];
void Dijkstra(int s){
for(int i=1;i<=5*n;i++)vis[i]=0,dis[i]=LLINF;
priority_queue<pair<LL,int> > q;
q.push(make_pair(-0,s)); dis[s]=0;
while(!q.empty()){
int u=q.top().second; q.pop();
if(vis[u])continue;
vis[u]=1;
for(int i=0;i<G[u].size();i++){
int v=G[u][i].first,c=G[u][i].second;
if(dis[v]>dis[u]+c){
dis[v]=dis[u]+c;
q.push(make_pair(-dis[v],v));
}
}
}
}
int main(){
while(~scanf("%d%d%d",&n,&m,&s)){
for(int i=0;i<=5*n;i++)G[i].clear();
idx=n;
build(1,1,n,0); build(1,1,n,1);
while(m--){
int t,u;
scanf("%d%d",&t,&u);
if(t==1){
int v,c; scanf("%d%d",&v,&c);
addedge(u,v,c);
}else if(t==2){
vs.clear();
int l,r,c; scanf("%d%d%d",&l,&r,&c);
get(1,1,n,l,r,0);
for(int i=0;i<vs.size();i++)addedge(u,vs[i],c);
}else{
vs.clear();
int l,r,c; scanf("%d%d%d",&l,&r,&c);
get(1,1,n,l,r,1);
for(int i=0;i<vs.size();i++)addedge(vs[i],u,c);
}
}Dijkstra(s);
for(int i=1;i<=n;i++){
if(dis[i]==LLINF)dis[i]=-1;
printf("%lld%c",dis[i],i==n?'\n':' ');
}
}return 0;
}
CodeForces 786B Legacy(线段树优化建图+最短路)的更多相关文章
- Codeforces.786B.Legacy(线段树优化建图 最短路Dijkstra)
题目链接 \(Description\) 有\(n\)个点.你有\(Q\)种项目可以选择(边都是有向边,每次给定\(t,u,v/lr,w\)): t==1,建一条\(u\to v\)的边,花费\(w\ ...
- 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 最 ...
- CF786B Legacy 线段树优化建图 + spfa
CodeForces 786B Rick和他的同事们做出了一种新的带放射性的婴儿食品(???根据图片和原文的确如此...),与此同时很多坏人正追赶着他们.因此Rick想在坏人们捉到他之前把他的遗产留给 ...
- G. 神圣的 F2 连接着我们 线段树优化建图+最短路
这个题目和之前写的一个线段树优化建图是一样的. B - Legacy CodeForces - 787D 线段树优化建图+dij最短路 基本套路 之前这个题目可以相当于一个模板,直接套用就可以了. 不 ...
- [Codeforces 1197E]Culture Code(线段树优化建图+DAG上最短路)
[Codeforces 1197E]Culture Code(线段树优化建图+DAG上最短路) 题面 有n个空心物品,每个物品有外部体积\(out_i\)和内部体积\(in_i\),如果\(in_i& ...
- 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,那么,该炸弹也会被引爆. 现在 ...
随机推荐
- Codeforces Round #525 (Div. 2)B. Ehab and subtraction
B. Ehab and subtraction 题目链接:https://codeforc.es/contest/1088/problem/B 题意: 给出n个数,给出k次操作,然后每次操作把所有数减 ...
- Java中文乱码问题(转)
解决JSP中文乱码问题 大家在JSP的开发过程中,经常出现中文乱码的问题,可能一至困扰着大家,现把JSP开发中遇到的中文乱码的问题及解决办法写出来供大家参考.首先了解一下Java中文问题的由来: Ja ...
- Python-Jenkins API使用
一.概述 最近在工作中需要用到在后台代码中触发Jenkins任务的构建,于是想到Jenkins是否有一些已经封装好的API类库提供,用于处理跟Jenkins相关的操作.下面就简单介绍下我的发现. 二. ...
- netty学习指南
这段时间领导让我熟悉Socket开发,我花了三周时间左右去学习相关的知识,包括Java socket开发,重点学习了netty这个异步非阻塞通信框架. 在这里把我学习过程中遇到的有用资料整理了,供大家 ...
- 【uva11468-Substring】AC自动机+dp
http://acm.hust.edu.cn/vjudge/problem/31655 题意:给定k个模板串,n个字符以及选择它的概率pro[i],要构造一个长度问L的字符串s,问s不包含任意一个模板 ...
- bzoj3223 文艺平衡树 codevs3303 翻转区间
splay模版题吧 只有区间翻转 至于为什么要把须翻转区间旋到根 因为查找一个区间可以先找出他左端点左边第一个点和右端点x右边第一个点y 然后将x旋到根节点 y旋到x的右儿子 这样x的右边的点就是所有 ...
- JSON的序列化和反序列化eval()和parse()方法以及stringfy()方法
1.json解析的方法有两种:eval()和parse()方法 eval() 较危险,不光解析了字符串,还解析了js方法,无论何时用eval()都是非常危险的.-----不建议使用JSON.parse ...
- syntax error near unexpected token `then'问题的解决
http://blog.csdn.net/gongmin856/article/details/7690917 #!/bin/bash #if program test echo 'a:' read ...
- linux 系统函数之 (dirname, basename)【转】
转自:http://blog.csdn.net/peter_cloud/article/details/9308333 版权声明:本文为博主原创文章,未经博主允许不得转载. 除非你的原件考虑跨平台. ...
- go语言中的json
结构体类型转化为json格式 package main import ( "encoding/json" "fmt" ) //如果要转化成json格式,那么成员 ...