描述

公元 2044 年,人类进入了宇宙纪元。L 国有 nn 个星球,还有 n−1n−1 条双向航道,每条航道建立在两个星球之间,这 n−1n−1 条 航道连通了 L 国的所有星球。

小 P 掌管一家物流公司,该公司有很多个运输计划,每个运输计划形如:有一艘物 流飞船需要从 uiui 号星球沿最快的宇航路径飞行到 vivi 号星球去。显然,飞船驶过一条航道是需要时间的,对于航道 jj,任意飞船驶过它所花费的时间为 tjtj,并且任意两艘飞船之间不会产生任何干扰。

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

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

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

格式

输入格式

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

接下来 n−1n−1 行描述航道的建设情况,其中第 ii 行包含三个整数 aiaibibi 和 titi,表示第 ii 条双向航道修建在 aiai 与 bibi 两个星球之间,任意飞船驶过它所花费的时间为 titi

接下来 mm 行描述运输计划的情况,其中第 jj 行包含两个正整数 ujuj 和 vjvj,表示第 jj 个 运输计划是从ujuj 号星球飞往 vjvj 号星球。

输出格式

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

我写了95分的二分,最后一个点莫名WA,可能是防AK的,不管了……

#include<iostream>
#include<cstdio>
#include<string>
#include<cstring>
#include<algorithm>
#include<vector>
using namespace std;
const int maxn = ;
struct edge{
int v;
int w;
int id;
int next;
};
struct QUERY{
int lca;
int dis;
int s;
int f;
};
long long n,m,flag,dep[maxn],dis_p[][maxn],pa[][maxn],vis[maxn],rec[maxn];
int head[maxn],cnt;
edge e[maxn];
QUERY query[maxn];
void ins(int u,int v,int w,int id){
cnt++;
e[cnt].v = v;
e[cnt].w = w;
e[cnt].id = id;
e[cnt].next = head[u];
head[u] = cnt;
}
bool cmp(QUERY a,QUERY b){
return a.dis < b.dis;
}
void input(){
cin>>n>>m;
edge tmp;
int u,v,w;
for(int i = ;i <= n-;i++){
scanf("%d%d%d",&u,&v,&w);
ins(u,v,w,i);
ins(v,u,w,i);
}
for(int i = ;i <= m;i++) scanf("%d%d",&query[i].s,&query[i].f);
}
void dfs(int x){
int k = ;
while(pa[k][x] && pa[k][pa[k][x]]){
pa[k+][x] = pa[k][pa[k][x]];
dis_p[k+][x] = dis_p[k][x] + dis_p[k][pa[k][x]];
k++;
}
for(int i = head[x];i;i = e[i].next){
if(e[i].v != pa[][x]){
pa[][e[i].v] = x;
dep[e[i].v] = dep[x] + ;
dis_p[][e[i].v] = e[i].w;
rec[e[i].v] = e[i].id;
dfs(e[i].v);
}
}
}
void get_dis(){
int x,y,k,p,d;
for(int i = ;i <= m;i++){
x = query[i].s;
y = query[i].f;
if(dep[x] > dep[y]) swap(x,y);
p = dep[y] - dep[x];
k = ;
d = ;
while(p){
if(p&){
d += dis_p[k][y];
y = pa[k][y];
}
p >>= ;
k++;
}
if(x == y){
query[i].lca = x;
query[i].dis = d;
continue;
}
k = ;
while(k >= ){
if(pa[k][x] == pa[k][y]) k--;
else{
d += dis_p[k][x] + dis_p[k][y];
x = pa[k][x];
y = pa[k][y];
k++;
}
}
query[i].lca = pa[][x];
d += dis_p[][x] + dis_p[][y];
query[i].dis = d;
}
sort(query+,query++m,cmp);
}
bool check(int t){
bool ok;
int u,v;
for(int i = m;i >= ;i--){
if(query[i].dis <= t) break;
flag++;
ok = false;
u = query[i].s;
while(u != query[i].lca){
if(query[i].dis - dis_p[][u] <= t && (i == m || vis[rec[u]] == flag-)){
ok = true;
vis[rec[u]] = flag;
}
u = pa[][u];
}
v = query[i].f;
while(v != query[i].lca){
if(query[i].dis - dis_p[][v] <= t && (i == m || vis[rec[v]] == flag-)){
ok = true;
vis[rec[v]] = flag;
}
v = pa[][v];
}
if(!ok) return false;
}
return true;
}
void dvd(){
int l = ,r = query[m].dis,mid,ans;
while(l <= r){
mid = (l + r) >> ;
if(check(mid)){
ans = mid;
r = mid - ;
}else{
l = mid + ;
}
}
cout<<ans;
}
int main(){
input();
dfs();
get_dis();
dvd();
return ;
}

noip2015 运输计划的更多相关文章

  1. bzoj 4326: NOIP2015 运输计划

    4326: NOIP2015 运输计划 Time Limit: 30 Sec Memory Limit: 128 MB Description 公元 2044 年,人类进入了宇宙纪元.L 国有 n 个 ...

  2. NOIP2015 运输计划(bzoj4326)

    4326: NOIP2015 运输计划 Time Limit: 30 Sec  Memory Limit: 128 MBSubmit: 886  Solved: 574[Submit][Status] ...

  3. [BZOJ4326][codevs4632][codevs5440][UOJ#150][NOIP2015]运输计划

    [BZOJ4326][codevs4632][codevs5440][UOJ#150][NOIP2015]运输计划 试题描述 公元 2044 年,人类进入了宇宙纪元. L 国有 n 个星球,还有 n− ...

  4. [NOIP2015]运输计划 D2 T3 LCA+二分答案+差分数组

    [NOIP2015]运输计划 D2 T3 Description 公元2044年,人类进入了宇宙纪元. L国有n个星球,还有n-1条双向航道,每条航道建立在两个星球之间,这n-1条航道连通了L国的所有 ...

  5. NOIP2015 运输计划(二分+LCA+差分)

    4326: NOIP2015 运输计划 Time Limit: 30 Sec  Memory Limit: 128 MBSubmit: 308  Solved: 208[Submit][Status] ...

  6. 数据结构(树链剖分):COGS 2109. [NOIP2015] 运输计划

    2109. [NOIP2015] 运输计划 ★★★   输入文件:transport.in   输出文件:transport.out   简单对比时间限制:1 s   内存限制:256 MB [题目描 ...

  7. BZOJ 4326 NOIP2015 运输计划 (二分+树上差分)

    4326: NOIP2015 运输计划 Time Limit: 30 Sec  Memory Limit: 128 MBSubmit: 1930  Solved: 1231[Submit][Statu ...

  8. cogs2109 [NOIP2015] 运输计划

    cogs2109 [NOIP2015] 运输计划 二分答案+树上差分. STO链剖巨佬们我不会(太虚伪了吧 首先二分一个答案,下界为0,上界为max{路径长度}. 然后判断一个答案是否可行,这里用到树 ...

  9. LOJ2425 NOIP2015 运输计划 【二分+LCA+树上差分】*

    LOJ2425 NOIP2015 运输计划 LINK 题意:给你一颗树,可以将任意一条边的权值变成0,然后求m条路径的长度的最小值 思路: 先二分最后的距离ans,然后我们把路程大于ans的所有路径拿 ...

  10. AC日记——[NOIP2015]运输计划 cogs 2109

    [NOIP2015] 运输计划 思路: 树剖+二分: 代码: #include <cstdio> #include <cstring> #include <iostrea ...

随机推荐

  1. Eclipse调试常用技巧

    1. 条件断点 断点大家都比较熟悉,在Eclipse Java 编辑区的行头双击就会得到一个断点,代码会运行到此处时停止. 条件断点,顾名思义就是一个有一定条件的断点,只有满足了用户设置的条件,代码才 ...

  2. Serial Port Programming using Win32 API(转载)

    In this tutorial we will learn How to communicate with an external device like a microcontroller boa ...

  3. HTTPS----安全超文本传输协议

    HTTPS协议详解HTTPS以保密为目标研发,简单讲是HTTP的安全版.其安全基础是SSL协议,因此加密的详细内容请看SSL.全称Hypertext Transfer Protocol over Se ...

  4. BZOJ 2243: [SDOI2011]染色 [树链剖分]

    2243: [SDOI2011]染色 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 6651  Solved: 2432[Submit][Status ...

  5. POJ3368Frequent values[RMQ 游程编码]

    Frequent values Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 17581   Accepted: 6346 ...

  6. iOS widget开发

    链接: iOS Widget开发 iOS开发之构建Widget iOS开发Widget iOS开发-widget基础 ios8新特性widget开发 ios 10 开发-widget实现 Widget ...

  7. (原创)JAVA多线程二线程池

    一,线程池的介绍 线程池包括一下三种: 线程池名称 创建方法 特点 其他 固定大小线程池 ExecutorService threadpool = Executors.newFixedThreadPo ...

  8. jenkins 入门教程(上)

    jenkins是一个广泛用于持续构建的可视化web工具,持续构建说得更直白点,就是各种项目的"自动化"编译.打包.分发部署.jenkins可以很好的支持各种语言(比如:java, ...

  9. knockoutJS学习笔记08:表单域绑定

    前面的绑定都是用在基本标签上,这章主要讲表单域标签的绑定. 一.value 绑定 绑定标签:input text.textarea. <p>用户名:<input type=" ...

  10. js 获取时间间隔

    现在感觉sublime   IDE 用着比较方便,也比较美观,不知道大家用的是啥ide.