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,那么,该炸弹也会被引爆. 现在 ...
随机推荐
- 数据仓库3级范式(3NF)基础
一.引言 最近在整理理大数据模式下的数据仓库数据模型,资料来自互联网和读过的数据仓库理论和实践相关. 二.3NF (1)1NF-无重复的列 数据库表的每一列都是不可分割的基本数据项,同一列中不能有多个 ...
- 对Office文档进行授权
Microsoft.Office.Interop.Word.ApplicationClass app = new Microsoft.Office.Interop.Word.ApplicationCl ...
- Eclipse CDT 调用printf/cout 控制台(console)无输出
转摘自:http://blog.csdn.net/dj0379/article/details/6940836 症状描述: 用Eclipse调试程序,执行printf和cout函数,但是console ...
- [06] JavaScript 类型
下面对知识点总结: 1.类型分类 a.原始类型:number, string, boolean, null, undefined b.对象类型:除了原始类型都是(例如:object,array, fu ...
- [05]Git查看、删除、重命名远程分支和tag
Git查看.删除.重命名远程分支和tag 2015-06-15:加入姊妹篇: 2013-11-06:加入重命名远程分支的内容: 2013-01-09:加入删除远程tag的内容. 姊妹篇:使用Git.G ...
- noip车站分级 拓扑排序
题目传送门 这道题呢 每次输入一段数就把1~n里面没有在这组数里面的数和他们连一波 表示这些数比他们等级低 然后就搞一搞就好了哇 #include<cstdio> #include< ...
- MyBatis系列三 之 使用getMapper剔除掉Dao的实现类
MyBatis系列三 之 使用getMapper剔除掉Dao的实现类 我们在系列一 中 我们使用的是Dao的实现类 来操作底层数据库,今天我们使用getMapper()来替换Dao的实现类, ...
- hdu 1399 Starship Hakodate-maru (暴力搜索)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1399 题目大意:找到满足i*i*i+j*(j+1)*(j+2)/6形式且小于等于n的最大值. #inc ...
- 从setting文件导包
两种方式 from project.settings.py import s3_key 第二种: from django.conf import setting s3_key = settings.S ...
- Unordered load/store queue
A method and processor for providing full load/store queue functionality to an unordered load/store ...