2109. [NOIP2015] 运输计划

★★★   输入文件:transport.in   输出文件:transport.out   简单对比
时间限制:1 s   内存限制:256 MB

【题目描述】

公元 2044 年,人类进入了宇宙纪元。

L 国有 n 个星球,还有 n-1 条双向航道,每条航道建立在两个星球之间,这 n-1 条航道连通了 L 国的所有星球。

小 P 掌管一家物流公司,该公司有很多个运输计划,每个运输计划形如:有一艘物

流飞船需要从 ui 号星球沿最快的宇航路径飞行到 vi 号星球去。显然,飞船驶过一条航道 是需要时间的,对于航道 j,任意飞船驶过它所花费的时间为 tj,并且任意两艘飞船之 间不会产生任何干扰。

为了鼓励科技创新,L 国国王同意小 P 的物流公司参与 L 国的航道建设,即允许小 P 把某一条航道改造成虫洞,飞船驶过虫洞不消耗时间。

在虫洞的建设完成前小 P 的物流公司就预接了 m 个运输计划。在虫洞建设完成后, 这 m 个运输计划会同时开始,所有飞船一起出发。当这 m 个运输计划都完成时,小 P 的 物流公司的阶段性工作就完成了。

如果小 P 可以自由选择将哪一条航道改造成虫洞,试求出小 P 的物流公司完成阶段 性工作所需要的最短时间是多少?

【输入格式】

第一行包括两个正整数 n、m,表示 L 国中星球的数量及小 P 公司预接的运输计划的数量,星球从 1 到 n 编号。

接下来 n-1 行描述航道的建设情况,其中第 i 行包含三个整数 ai, bi 和 ti,表示第i 条双向航道修建在 ai 与 bi 两个星球之间,任意飞船驶过它所花费的时间为 ti。 接下来 m 行描述运输计划的情况,其中第 j 行包含两个正整数 uj 和 vj,表示第 j 个运输计划是从 uj 号星球飞往 vj 号星球。

【输出格式】

共 1 行,包含 1 个整数,表示小 P 的物流公司完成阶段性工作所需要的最短时间。

【样例输入】

6 3
1 2 3
1 6 4
3 1 7
4 3 6
3 5 5
3 6
2 5
4 5

【样例输出】

11

【提示】

所有测试数据的范围和特点如下表所示

请注意常数因子带来的程序效率上的影响。

  哎,拼命优化还是95分。

 #include <algorithm>
#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;
const int maxn=; int n,m;
int E[maxn][],cnt,fir[maxn],to[maxn<<],nxt[maxn<<],val[maxn<<];
void addedge(int a,int b,int v){
nxt[++cnt]=fir[a];to[cnt]=b;fir[a]=cnt;val[cnt]=v;
} int dep[maxn],son[maxn],sz[maxn],fa[maxn],dis[maxn]; void DFS(int x){
sz[x]=;
for(int i=fir[x];i;i=nxt[i])
if(to[i]!=fa[x]){
dep[to[i]]=dep[x]+;
dis[to[i]]=dis[x]+val[i];
fa[to[i]]=x;
DFS(to[i]);
sz[x]+=sz[to[i]];
if(sz[son[x]]<sz[to[i]])
son[x]=to[i];
}
} int top[maxn],ID[maxn],tot;
void DFS(int x,int tp){
ID[x]=++tot;top[x]=tp;
if(son[x])DFS(son[x],tp);
for(int i=fir[x];i;i=nxt[i])
if(!ID[to[i]])
DFS(to[i],to[i]);
} int Lca(int x,int y){
while(top[x]!=top[y]){
if(dep[top[x]]<dep[top[y]])swap(x,y);
x=fa[top[x]];
}
return dep[x]>dep[y]?y:x;
} int Mx1[maxn*],Mx2[maxn*];
struct Node{
int l,r;
Node(int L=,int R=){
l=L;r=R;
}
bool operator <(const Node &b)const{
return l<b.l;
}
}st[maxn]; int V[maxn];
void Update1(int x,int l,int r,int a,int b,int g){
if(l>=a&&r<=b){
Mx1[x]=max(Mx1[x],g);
return;
}
int mid=(l+r)>>;
if(mid>=a)Update1(x<<,l,mid,a,b,g);
if(mid<b)Update1(x<<|,mid+,r,a,b,g);
} void Update2(int x,int l,int r,int a,int b,int g){
if(l>=a&&r<=b){
Mx2[x]=max(Mx2[x],g);
return;
}
int mid=(l+r)>>;
if(mid>=a)Update2(x<<,l,mid,a,b,g);
if(mid<b)Update2(x<<|,mid+,r,a,b,g);
} int Query1(int x,int l,int r,int g){
if(l==r)
return Mx1[x];
int mid=(l+r)>>;
if(mid>=g)return max(Query1(x<<,l,mid,g),Mx1[x]);
else return max(Query1(x<<|,mid+,r,g),Mx1[x]);
} int Query2(int x,int l,int r,int g){
if(l==r)
return Mx2[x];
int mid=(l+r)>>;
if(mid>=g)return max(Query2(x<<,l,mid,g),Mx2[x]);
else return max(Query2(x<<|,mid+,r,g),Mx2[x]);
}
void Solve(int x,int y,int sum){
int tp=;
while(top[x]!=top[y]){
if(dep[top[x]]<dep[top[y]])swap(x,y);
st[++tp]=Node(ID[top[x]],ID[x]);
x=fa[top[x]];
}
if(dep[x]<dep[y])swap(x,y);
if(x!=y)st[++tp]=Node(ID[son[y]],ID[x]);
sort(st,st+tp+);
for(int i=;i<=tp;i++)
Update1(,,n,st[i].l,st[i].r,sum); int L=;
for(int i=;i<=tp;i++){
if(L<=st[i].l-)
Update2(,,n,L,st[i].l-,sum);
L=st[i].r+;
}
if(L<=n)Update2(,,n,L,n,sum);
} int main(){
#ifndef ONLINE_JUDGE
freopen("transport.in","r",stdin);
freopen("transport.out","w",stdout);
#endif
scanf("%d%d",&n,&m);
for(int i=;i<n;i++){
scanf("%d%d%d",&E[i][],&E[i][],&E[i][]);
addedge(E[i][],E[i][],E[i][]);
addedge(E[i][],E[i][],E[i][]);
} DFS();
DFS(,); memset(Mx1,0x80,sizeof(Mx1));
memset(Mx2,0x80,sizeof(Mx2)); for(int i=;i<n;i++){
if(dep[E[i][]]<dep[E[i][]])
swap(E[i][],E[i][]);
V[E[i][]]=E[i][];
} int Max=,pa,pb;
while(m--){
int a,b,lca;
scanf("%d%d",&a,&b);
lca=Lca(a,b);
if(dis[a]+dis[b]-*dis[lca]>Max){
pa=a,pb=b;
Max=dis[a]+dis[b]-*dis[lca];
}
Solve(a,b,dis[a]+dis[b]-*dis[lca]);
} int ans=;
while(pa!=pb){
if(dep[pa]<dep[pb])swap(pa,pb);
int ret=max(Query1(,,n,ID[pa])-V[pa],Query2(,,n,ID[pa]));
ans=min(ans,ret);
pa=fa[pa];
} printf("%d\n",ans);
return ;
}

数据结构(树链剖分):COGS 2109. [NOIP2015] 运输计划的更多相关文章

  1. 数据结构(树链剖分):BZOJ 4034: [HAOI2015]T2

    Description 有一棵点数为 N 的树,以点 1 为根,且树点有边权.然后有 M 个 操作,分为三种: 操作 1 :把某个节点 x 的点权增加 a . 操作 2 :把某个节点 x 为根的子树中 ...

  2. 数据结构--树链剖分准备之LCA

    有关LCA的模板题    传送门 题目描述 如题,给定一棵有根多叉树,请求出指定两个点直接最近的公共祖先. 输入输出格式 输入格式: 第一行包含三个正整数N.M.S,分别表示树的结点个数.询问的个数和 ...

  3. 数据结构(树链剖分,堆):HNOI 2016 network

    2215. [HNOI2016]网络 ★★★☆   输入文件:network_tenderRun.in   输出文件:network_tenderRun.out   简单对比时间限制:2 s   内存 ...

  4. cogs 2109. [NOIP 2015] 运输计划 提高组Day2T3 树链剖分求LCA 二分答案 差分

    2109. [NOIP 2015] 运输计划 ★★★☆   输入文件:transport.in   输出文件:transport.out   简单对比时间限制:3 s   内存限制:256 MB [题 ...

  5. BZOJ_4326_[NOIP2015]_运输计划_(二分+LCA_树链剖分/Tarjan+差分)

    描述 http://www.lydsy.com/JudgeOnline/problem.php?id=4326 给出一棵带有边权的树,以及一系列任务,任务是从树上的u点走到v点,代价为u到v路径上的权 ...

  6. 树链剖分-Hello!链剖-[NOIP2015]运输计划-[填坑]

    This article is made by Jason-Cow.Welcome to reprint.But please post the writer's address. http://ww ...

  7. bzoj 4326: NOIP2015 运输计划(二分+树链剖分)

    传送门 题解: 树链剖分快速求解任意两点间的路径的权值和: 然后,二分答案: 此题的难点是如何快速求解重合路径? 差分数组可以否??? 在此之前先介绍一下相关变量: int fa[maxn]; int ...

  8. JZYZOJ1454 NOIP2015 D2T3_运输计划 二分 差分数组 lca tarjan 树链剖分

    http://172.20.6.3/Problem_Show.asp?id=1454 从这道题我充分认识到我的脑子里好多水orz. 如果知道了这个要用二分和差分写,就没什么思考上的难点了(屁咧你写了一 ...

  9. NOIP2015 运输计划 - 二分 + 树链剖分 / (倍增 + 差分)

    BZOJ CodeVS Uoj 题目大意: 给一个n个点的边带权树,给定m条链,你可以选择树中的任意一条边,将它置为0,使得最长的链长最短. 题目分析: 最小化最大值,二分. 二分最短长度mid,将图 ...

随机推荐

  1. Java 8 被动迭代式特性介绍(转自IBM)

    编程语言一般都需要提供一种机制用来遍历软件对象的集合,现代的编程语言支持更为复杂的数据结构,如列表.集合.映射和数组.遍历能力是通过公共方法提供,而内部细节都隐藏在类的私有部分,所以程序员不需要了解其 ...

  2. HTML5表单提交和PHP环境搭建

    HTML5表单提交相关内容和PHP环境搭建需要的软件(只备注) (2)举例介绍 (3)PHP环境搭建

  3. struts_ognl详解

  4. 使用JavaScriptSerializer序列化集合、字典、数组、DataTable为JSON字符串 分类: 前端 数据格式 JSON 2014-10-30 14:08 169人阅读 评论(0) 收藏

    一.JSON简介 JSON(JavaScript Object Notation,JavaScript对象表示法)是一种轻量级的数据交换格式. JSON是"名值对"的集合.结构由大 ...

  5. Android之提交数据到服务端方法简单封装

    在Android应用中,除了单机版的应用,其余的应用免不了需要频繁地与服务端进行数据交互,如果每一种方法都独立写一段代码,那会造成代码大量重复,冗余,这不是我们所希望的,所以我们可以对其进行一些封装, ...

  6. 解读oracle执行计划-待续

    Cost(%CPU): 优化器估算出完成当前操作的代价(包含子操作的代价),它是IO代价和CPU 代价总和.其中IO代价是最基本的代价.而对于CPU代价,在默认情况下,优化器会将CPU代价计算在内,而 ...

  7. 【深度解析】Google第二代深度学习引擎TensorFlow开源

    作者:王嘉俊 王婉婷 TensorFlow 是 Google 第二代深度学习系统,今天宣布完全开源.TensorFlow 是一种编写机器学习算法的界面,也可以编译执行机器学习算法的代码.使用 Tens ...

  8. 292. Nim Game(C++)

    292. Nim Game(C++) You are playing the following Nim Game with your friend: There is a heap of stone ...

  9. 【POJ1417】【带标记并查集+DP】True Liars

    Description After having drifted about in a small boat for a couple of days, Akira Crusoe Maeda was ...

  10. nginx插件ngx_lua

    ngx_lua是淘宝的维护的产品,真心不错.配置文件包含可以做很多事情的lua脚本. 公司有个产品对注册的广告盒子进行反向代理,这样可以在盒子上做很多事情:和服务器通信,远程控制盒子等等.nginx反 ...