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,那么,该炸弹也会被引爆. 现在 ...
随机推荐
- React & Redux 的一些基本知识点
一.React.createClass 跟 React.Component 的区别在于后者使用了ES6的语法,用constructor构造器来构造默认的属性和状态. 1. React.createCl ...
- 关于Maven项目install时出现No compiler is provided in this environment的处理
关于Maven项目build时出现No compiler is provided in this environment的处理 新配置的Eclipse环境,运行现有项目没问题,一日,从svn上检出了一 ...
- HDU4370:0 or 1(最短路)
0 or 1 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4370 Description: Given a n*n matrix Cij (1< ...
- 解决es6中webstrom不支持import的一个简单方法
代码如下: export_one.js的代码如下: export function one() { console.log('one'); } export function two() { cons ...
- js中连写两个?:三元运算符语法解释
在angular 源码中有连写两个三元运算符的代码: var hash = isString(hash) ? hash : isNumber(hash) ? hash.toString() :$loc ...
- egrep对于conf文件中去掉#注释,排除无用项
[root@localhost conf]# egrep -v "#|^$" nginx.conf.default > nginx.conf dd
- Phantomjs设置浏览器useragent的方式
Selenium中使用PhantomJS,设置User-Agent的方法. 默认情况下,是没有自动设置User-Agent的:设置PhantomJS的user-agent def __init__(s ...
- Spring学习--通过注解配置 Bean (一)
在 classpath 中扫描组件: 组件扫描(component scanning): Spring 能够从 classpath 下自动扫描 , 侦测和实例化具有特定注解的组件. 特定组件包括: @ ...
- eclipse 4.2生成wsdl 客户端
eclipse版本 4.2 64位 ,jdk 1.6 64位 Eclipse Java EE IDE for Web Developers. Version: Juno Service Rel ...
- js点亮星星评分并获取参数的js代码
点亮星星评分后,点击按钮,立即获得分数参数值,方便不想使用ajax传参的朋友 http://demo.jb51.net/js/2014/jsxxdf/demo2.html <!DOCTYPE h ...