P2680

题目的大意就是走完m条路径所需要的最短时间(边权是时间), 其中我们可以把一条边的权值变成0(也就是题目所说的虫洞)。

可以考虑二分答案x,找到一条边,使得所有大于x的路径经过这条边(差分维护),并且路径减去这条边的边权后小等于x,通过这样判定x是否可行。

 1 #include <bits/stdc++.h>
2 #define ll long long
3 using namespace std;
4 const int N = 3e5 + 10;
5 int tot, head[N], to[N << 1], nxt[N << 1], edge[N << 1];
6 int n, m, fa[N][25], dep[N], dis[N], pre[N], num[N];
7 struct node {
8 int x, y, lca;
9 }q[N];
10 void add(int x, int y, int z) {
11 nxt[++ tot] = head[x], head[x] = tot, to[tot] = y, edge[tot] = z;
12 }
13 void dfs(int u, int f) {
14 dep[u] = dep[f] + 1;
15 fa[u][0] = f;
16 for (int i = 1; i <= 20; i ++)
17 fa[u][i] = fa[fa[u][i - 1]][i - 1];
18 for (int i = head[u]; i; i = nxt[i]) {
19 int v = to[i];
20 if (v == f) continue;
21 pre[v] = edge[i];//v所在这条边的边权
22 dis[v] = dis[u] + edge[i];
23 dfs(v, u);
24 }
25 }
26 int getlca(int x, int y) {
27 if (dep[x] < dep[y]) swap(x, y);
28 for (int i = 20; i >= 0; i --) {
29 if (dep[fa[x][i]] >= dep[y]) x = fa[x][i];
30 }
31 if (x == y) return x;
32 for (int i = 20; i >= 0; i --) {
33 if (fa[x][i] != fa[y][i]) x = fa[x][i], y = fa[y][i];
34 }
35 return fa[x][0];
36 }
37 int flag, cnt, maxn;
38 int judge(int u, int f, int cnt, int maxn) {//返回子树和
39 int k = num[u];
40 for (int i = head[u]; i; i = nxt[i]) {
41 int v = to[i];
42 if (v == f) continue;
43 k += judge(v, u, cnt, maxn);
44 }
45 if (k >= cnt && pre[u] >= maxn) flag = 1;
46 //所有>mid的边都经过u所在这条边i,且i的权值满足条件
47 return k;
48 }
49 bool check(ll mid) {
50 memset(num, 0, sizeof num);
51 maxn = cnt = flag = 0;
52 for (int i = 1; i <= m; i ++) {
53 int d = dis[q[i].x] + dis[q[i].y] - 2 * dis[q[i].lca];
54 if (d > mid) {
55 num[q[i].x] ++, num[q[i].y] ++, num[q[i].lca] -= 2;
56 cnt ++;
57 maxn = max(maxn, d);
58 }
59 }
60 if (!cnt) return 1; // !!!!!
61 judge(1, 0, cnt, maxn - mid);
62 return flag;
63 }
64 int main() {
65 scanf("%d %d", &n, &m);
66 for (int i = 1; i < n; i ++) {
67 int a, b, c;
68 scanf("%d %d %d", &a, &b, &c);
69 add(a, b, c), add(b, a, c);
70 }
71 dfs(1, 0);
72 for (int i = 1; i <= m; i ++) {
73 scanf("%d %d", &q[i].x, &q[i].y);
74 q[i].lca = getlca(q[i].x, q[i].y);
75 }
76 ll l = 0, r = 300000000;
77 while (l < r) {
78 ll mid = (l + r) >> 1;
79 if (check(mid)) r = mid;
80 else l = mid + 1;
81 }
82 printf("%lld\n", l);
83 return 0;
84 }

P2680 [NOIP2015 提高组] 运输计划 (树上差分-边差分)的更多相关文章

  1. 洛谷 P2680 [NOIP2015 提高组] 运输计划

    链接:P2680 题意: 在树上把一条边边权变为0使得最长给定路径最短 分析: 最大值最小可以想到二分答案,对于每一个mid,寻找所有大于mid的路径,再寻找是否存在一条边使得删去它后大于mid的路径 ...

  2. NOIP2015 提高组] 运输计划

    码农题啊兄弟们. 随便考虑二分一下,然后发现要取一条满足性质的边. 被所有大于\(mid\)的路径都覆盖,取了之后能把他们都弄到小于\(mid\) 那就树上差分再处理一下. 写了\(180h\),老年 ...

  3. [NOIP2015 提高组] 运输计划题解

    题目链接:P2680 [NOIP2015 提高组] 运输计划 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 看了好长时间题解才终于懂的,有关lca和二分答案的题解解释的不详细,一时 ...

  4. [NOIP2015提高组]运输计划

    题目:BZOJ4326.洛谷P2680.Vijos P1983.UOJ#150.codevs4632.codevs5440. 题目大意:有一棵带权树,有一些运输计划,第i个运输计划从ai到bi,耗时为 ...

  5. 【数据结构】运输计划 NOIP2015提高组D2T3

    [数据结构]运输计划 NOIP2015提高组D2T3 >>>>题目 [题目描述] 公元 2044 年,人类进入了宇宙纪元.L 国有 n 个星球,还有 n−1 条双向航道,每条航 ...

  6. [NOIP 2015]运输计划-[树上差分+二分答案]-解题报告

    [NOIP 2015]运输计划 题面: A[NOIP2015 Day2]运输计划 时间限制 : 20000 MS 空间限制 : 262144 KB 问题描述 公元 2044 年,人类进入了宇宙纪元. ...

  7. 【题解】NOIP2015提高组 复赛

    [题解]NOIP2015提高组 复赛 传送门: 神奇的幻方 \([P2615]\) 信息传递 \([P2661]\) 斗地主 \([P2668]\) 跳石头 \([P2678]\) 子串 \([P26 ...

  8. 洛谷 P2678 & [NOIP2015提高组] 跳石头

    题目链接 https://www.luogu.org/problemnew/show/P2678 题目背景 一年一度的“跳石头”比赛又要开始了! 题目描述 这项比赛将在一条笔直的河道中进行,河道中分布 ...

  9. 【二分查找】 跳石头NOIP2015提高组 D2T1

    [二分查找]跳石头NOIP2015提高组 D2T1 >>>>题目 [题目描述] 一年一度的“跳石头”比赛又要开始了! 这项比赛将在一条笔直的河道中进行,河道中分布着一些巨大岩石 ...

随机推荐

  1. 使用Python3.7配合协同过滤算法(base on user,基于人)构建一套简单的精准推荐系统(个性化推荐)

    原文转载自「刘悦的技术博客」https://v3u.cn/a_id_136 时至2020年,个性化推荐可谓风生水起,Youtube,Netflix,甚至于Pornhub,这些在互联网上叱咤风云的流媒体 ...

  2. 小白之Python基础(五)

    使用dict和set 1.dict :是direction字典的缩写 1) 通过{ }创建,使用健-值(key-value)存储:用"键值对"表示映射关系,例如 {名字:对应的成绩 ...

  3. show create table底层流程跟踪

    GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. 导语 SHOW CREATE TABLE语句用于为指定表/视图显示创建的语句,本文将简要描述如何在MySQL源码里跟踪和学 ...

  4. 技术分享|sysbench 压测工具用法浅析

    GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. 介绍 新业务上线的时候通常需要对数据库性能进行压力测试,以确认是否满足需要,今天简单介绍下sysbench的用法: 1.s ...

  5. DolphinScheduler 功能开发:⼯作流级别任务空跑(后端),测试工作流是否正确执行...

    点击上方 蓝字关注我们 ✎ 编 者 按 在今年由中国科学院软件研究所主办的开源软件所供应链点亮计划-开源之夏活动中,有不少小伙伴提交了关于 DolphinScheduler 的项目,本期是来自成都信息 ...

  6. MyBatis ognl.NoSuchPropertyException 或者 Invalid bound statement (not found)

    描述 SpringBoot + Mybatis-plus 项目,运行时出现如下错误: ognl.NoSuchPropertyException:没有对应属性异常 Invalid bound state ...

  7. 项目一共30个模块,你叫我maven版本一个个手动改?

    大家好呀,我是铂赛东,一个乱入公众号博主的开源作者.今天分享一个maven小技巧,希望帮助到大家. 之前有个群友私聊问我,如何快速统一去更改项目中所有的maven版本号,他说之前都是手动一个个去修改, ...

  8. Java核心知识体系4:AOP原理和切面应用

    1 概述 我们所说的Aop(即面向切面编程),即面向接口,也面向方法,在基于IOC的基础上实现. Aop最大的特点是对指定的方法进行拦截并增强,这种增强的方式不需要业务代码进行调整,无需侵入到业务代码 ...

  9. 46th ECfinal 游记

    Day0 坐高铁坐了七小时从北戴河到西安,但第一次线下赛,来的路上还是很激动的 路上看到华山,下次来西安一定去爬 刚下高铁站遇到了一个不知道干啥的xjj xjj:可以占用您一点时间吗?谢谢了. 我:不 ...

  10. sftp服务器的搭建与连接

    在个人租用的vps上搭建sftp服务器并通过本机连接上去 本实验所需:Xshell(xshell中包含xftp).一台vps(windows系统) sftp是一种协议,即SSH File Transf ...