【题目链接】 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(线段树优化建图+最短路)的更多相关文章

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

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

  2. 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 最 ...

  3. CF786B Legacy 线段树优化建图 + spfa

    CodeForces 786B Rick和他的同事们做出了一种新的带放射性的婴儿食品(???根据图片和原文的确如此...),与此同时很多坏人正追赶着他们.因此Rick想在坏人们捉到他之前把他的遗产留给 ...

  4. G. 神圣的 F2 连接着我们 线段树优化建图+最短路

    这个题目和之前写的一个线段树优化建图是一样的. B - Legacy CodeForces - 787D 线段树优化建图+dij最短路 基本套路 之前这个题目可以相当于一个模板,直接套用就可以了. 不 ...

  5. [Codeforces 1197E]Culture Code(线段树优化建图+DAG上最短路)

    [Codeforces 1197E]Culture Code(线段树优化建图+DAG上最短路) 题面 有n个空心物品,每个物品有外部体积\(out_i\)和内部体积\(in_i\),如果\(in_i& ...

  6. BZOJ5017 [SNOI2017]炸弹 - 线段树优化建图+Tarjan

    Solution 一个点向一个区间内的所有点连边, 可以用线段树优化建图来优化 : 前置技能传送门 然后就得到一个有向图, 一个联通块内的炸弹可以互相引爆, 所以进行缩点变成$DAG$ 然后拓扑排序. ...

  7. 【BZOJ3681】Arietta 树链剖分+可持久化线段树优化建图+网络流

    [BZOJ3681]Arietta Description Arietta 的命运与她的妹妹不同,在她的妹妹已经走进学院的时候,她仍然留在山村中.但是她从未停止过和恋人 Velding 的书信往来.一 ...

  8. 【ARC069F】Flags 2-sat+线段树优化建图+二分

    Description ​ 数轴上有 n 个旗子,第 ii 个可以插在坐标 xi或者 yi,最大化两两旗子之间的最小距离. Input ​ 第一行一个整数 N. ​ 接下来 N 行每行两个整数 xi, ...

  9. 【bzoj5017】[Snoi2017]炸弹 线段树优化建图+Tarjan+拓扑排序

    题目描述 在一条直线上有 N 个炸弹,每个炸弹的坐标是 Xi,爆炸半径是 Ri,当一个炸弹爆炸时,如果另一个炸弹所在位置 Xj 满足:  Xi−Ri≤Xj≤Xi+Ri,那么,该炸弹也会被引爆.  现在 ...

随机推荐

  1. Angular 遍历循环数组

    var app = angular.module('Mywind',['ui.router']) app.controller('Myautumn',function($scope,$http,$fi ...

  2. Angular Cookie 读写

    var app = angular.module('Mywind',['ui.router']) app.controller('Myautumn',function($scope,$http,$fi ...

  3. ios webapp调试神器MIHTool

    android平台有直接用chrome beta就可以调试,具体操作办法可以查看这篇教程<Android 设备 Chrome 远程调试>Mac的高富帅直接可以用safari提供“web检查 ...

  4. css中文本超出部分省略号代替

    p{ width: 100px; //设置p标签宽度 white-space: nowrap; //文本超出P标签宽度不换行,而是溢出 overflow: hidden; //文本超出P标签,超出部分 ...

  5. React 开发常见报错解决方法

    1. 使用 redux 的异步 action 时浏览器报错: Error: Actions must be plain objects. Use custom middleware for async ...

  6. 数学:乘法逆元-拓展GCD

    乘法逆元应用在组合数学取模问题中,这里给出的实现不见得好用 给出拓展GCD算法: 扩展欧几里得算法是指对于两个数a,b 一定能找到x,y(均为整数,但不满足一定是正数) 满足x*a+y*b=gcd(a ...

  7. 图论:Gale-Shapley算法

    Gale-Shapley算法又叫做延迟认可算法,它可以解决这么一个问题 一共有N位男士和N位女士 每位男士对每位女士都有一个好感度,让他们结合成为N对夫妻,要求男士优先表白,最后问结合情况 第一轮,每 ...

  8. sort函数_C++

    C++的STL库里有一个 sort 函数,它就是随机化快速排序,速度比快速排序还快,因为它克服了逆序时被卡成O(n2)的情况 想要使用 sort 首先要在头文件里申明 #include<algo ...

  9. 嵌入式上 iscsi实现

    前言 去年公司设备(haisi3516)上需要提供iscsi的功能,于是花了几天时间探究了下.linux内核(2.6.xx)支持iscsi,只是我发现当时我们设备的内核编译时没有选上,于是重新编译了内 ...

  10. rtmp服务端实现

    前言 网上好像没一篇讲的很完善的,可能和公司保密有关吧.先就最让人困惑(至少我是这样)且网上也很少找到答案的一个点讲一下id各是什么意思? (如果我哪里理解错了,希望大神指出,毕竟我也是看了好多资料及 ...