NOIP2015 提高组] 运输计划
码农题啊兄弟们。
随便考虑二分一下,然后发现要取一条满足性质的边。
被所有大于\(mid\)的路径都覆盖,取了之后能把他们都弄到小于\(mid\)
那就树上差分再处理一下。
写了\(180h\),老年人复建训练。
NOIP2015 提高组] 运输计划
// Problem: P2680 [NOIP2015 提高组] 运输计划
// Contest: Luogu
// URL: https://www.luogu.com.cn/problem/P2680
// Memory Limit: 292.97 MB
// Time Limit: 1000 ms
//
// Powered by CP Editor (https://cpeditor.org)
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#define ll long long
#define N 300005
inline ll read(){
char a = getchar();
ll ans = 0;
while(!((a <= '9') && (a >= '0')))
a = getchar();
while((a <= '9') && (a >= '0'))
ans = (ans << 3) + (ans << 1) + (a - '0'),a = getchar();
return ans;
}
struct P{
ll to,v,next;
}e[N << 1];
ll cnt,head[N],s[N];
inline void add(int x,int y,int v){
e[++cnt].to = y;
e[cnt].v = v;
e[cnt].next = head[x];
head[x] = cnt;
}
ll n,m;
struct T{
ll l,r,sl;
}ta[N];
bool operator < (T a,T b){
return a.sl < b.sl;
}
ll dep[N],f[N][32];
inline void dfs(int u,int fa){
f[u][0] = fa;
dep[u] = dep[fa] + 1;
for(int i = 1;i <= 30;++i)
f[u][i] = f[f[u][i - 1]][i - 1];
for(int i = head[u];i;i = e[i].next){
int v = e[i].to;
if(v == fa)continue;
s[v] = s[u] + e[i].v;
dfs(v,u);
}
}
inline ll lca(ll x,ll y){
if(dep[x] < dep[y])
std::swap(x,y);
for(int i = 30;i >= 0;--i){
if(dep[f[x][i]] >= dep[y])
x = f[x][i];
if(x == y)
return x;
}
for(int i = 20;i >= 0;--i){
if(f[x][i] != f[y][i]){
x = f[x][i];
y = f[y][i];
}
}
return f[x][0];
}
ll tag[N],va[N];
ll need;
bool p;
ll x;
inline void del(int u,int fa){
for(int i = head[u];i;i = e[i].next){
int v = e[i].to;
if(v != fa){
del(v,u);
va[u] += va[v];
}
}
va[u] += tag[u];
// std::cout<<u<<" "<<tag[u]<<" "<<va[u]<<std::endl;
}
inline void dfs2(int u,int fa,int v){
// std::cout<<u<<" "<<va[u]<<" "<<tag[u]<<" "<<fa<<" "<<v<<std::endl;
if(va[u] == need && ta[m].sl - v <= x){
p = 1;
return ;
}
for(int i = head[u];i;i = e[i].next){
int vi = e[i].to;
if(vi == fa)
continue;
dfs2(vi,u,e[i].v);
}
}
inline bool check(){
// std::cout<<x<<":"<<std::endl;
std::memset(tag,0,sizeof(tag));
std::memset(va,0,sizeof(va));
need = 0;
for(int i = m;i >= 1;--i){
if(ta[i].sl > x){
int Lca = lca(ta[i].l,ta[i].r);
need ++ ;
if(Lca == ta[i].l){
tag[ta[i].l] -- ;
tag[ta[i].r] ++ ;
}else if(Lca == ta[i].r){
tag[ta[i].r] -- ;
tag[ta[i].l] ++;
}else {
// std::cout<<Lca<<" "<<ta[i].l<<" "<<ta[i].r<<std::endl;
tag[Lca] -= 2;
tag[ta[i].l] ++ ;
tag[ta[i].r] ++ ;
}
}
}
del(1,0);
p = 0;
dfs2(1,0,0);
return p;
}
inline void find_ans(){a
std::sort(ta + 1,ta + m + 1);
ll l = 0,r = ta[m].sl;
#define mid ((l + r) >> 1)
while(l + 1 < r){
x = mid;
// std::cout<<l<<" "<<r<<" ";
if(check())
r = mid;
else
l = mid;
// std::cout<<l<<" "<<r<<std::endl;
}ac
r ++ ;
while(x = r - 1,check())
r--;
std::cout<<r<<std::endl;
}
int main(){
n = read(),m = read();
for(int i = 1;i <= n - 1;++i){
ll l,r,v;
l = read(),r = read(),v = read();
add(l,r,v);
add(r,l,v);
}
for(int i = 1;i <= m;++i)
ta[i].l = read(),ta[i].r = read();
dfs(1,0);
for(int i = 1;i <= m;++i){
ll Lca = lca(ta[i].l,ta[i].r);
ta[i].sl = s[ta[i].l] + s[ta[i].r] - 2 * s[Lca];
}
// for(int i = 1;i <= m;++i)
// std::cout<<ta[i].sl<<std::endl;
find_ans();
}
NOIP2015 提高组] 运输计划的更多相关文章
- [NOIP2015 提高组] 运输计划题解
题目链接:P2680 [NOIP2015 提高组] 运输计划 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 看了好长时间题解才终于懂的,有关lca和二分答案的题解解释的不详细,一时 ...
- [NOIP2015提高组]运输计划
题目:BZOJ4326.洛谷P2680.Vijos P1983.UOJ#150.codevs4632.codevs5440. 题目大意:有一棵带权树,有一些运输计划,第i个运输计划从ai到bi,耗时为 ...
- 洛谷 P2680 [NOIP2015 提高组] 运输计划
链接:P2680 题意: 在树上把一条边边权变为0使得最长给定路径最短 分析: 最大值最小可以想到二分答案,对于每一个mid,寻找所有大于mid的路径,再寻找是否存在一条边使得删去它后大于mid的路径 ...
- P2680 [NOIP2015 提高组] 运输计划 (树上差分-边差分)
P2680 题目的大意就是走完m条路径所需要的最短时间(边权是时间), 其中我们可以把一条边的权值变成0(也就是题目所说的虫洞). 可以考虑二分答案x,找到一条边,使得所有大于x的路径都经过这条边(差 ...
- 【数据结构】运输计划 NOIP2015提高组D2T3
[数据结构]运输计划 NOIP2015提高组D2T3 >>>>题目 [题目描述] 公元 2044 年,人类进入了宇宙纪元.L 国有 n 个星球,还有 n−1 条双向航道,每条航 ...
- 【题解】NOIP2015提高组 复赛
[题解]NOIP2015提高组 复赛 传送门: 神奇的幻方 \([P2615]\) 信息传递 \([P2661]\) 斗地主 \([P2668]\) 跳石头 \([P2678]\) 子串 \([P26 ...
- 洛谷 P2678 & [NOIP2015提高组] 跳石头
题目链接 https://www.luogu.org/problemnew/show/P2678 题目背景 一年一度的“跳石头”比赛又要开始了! 题目描述 这项比赛将在一条笔直的河道中进行,河道中分布 ...
- 【二分查找】 跳石头NOIP2015提高组 D2T1
[二分查找]跳石头NOIP2015提高组 D2T1 >>>>题目 [题目描述] 一年一度的“跳石头”比赛又要开始了! 这项比赛将在一条笔直的河道中进行,河道中分布着一些巨大岩石 ...
- [NOIP2015] 提高组 洛谷P2615 神奇的幻方
题目描述 幻方是一种很神奇的N*N矩阵:它由数字1,2,3,……,N*N构成,且每行.每列及两条对角线上的数字之和都相同. 当N为奇数时,我们可以通过以下方法构建一个幻方: 首先将1写在第一行的中间. ...
随机推荐
- Win10 配置JDK1.8 (JDK 8)环境变量
JDK的安装: 1. JDK安装过程中,一般X掉公共JRE,因为JDK包含了JRE: 环境变量的配置: 1. 打开环境变量,编辑系统变量,新建: 变量名:JAVA_HOME 变量值:D:\so ...
- SpringCloud微服务实战——搭建企业级开发框架(二):环境准备
这里简单说明一下在Windows系统下开发SpringCloud项目所需要的的基本环境,这里只说明开发过程中基础必须的软件,其他扩展功能(Docker,k8s,MinIO,XXL-JOB,EKL,Ke ...
- BUAA 2020 软件工程 提问回顾与个人总结
BUAA 2020 软件工程 提问回顾与个人总结 Author: 17373051 郭骏 项目 内容 这个作业属于哪个课程 2020春季计算机学院软件工程(罗杰 任健) 这个作业的要求在哪里 提问回顾 ...
- Noip模拟11 2021.7.11
T1 math 其实看看题面,看看给的那机组数据即可看出规律了(然而当时并没有,只是发现模数的循环节,存了个vector,接下来就暴力了) 有个柿子: 其实就是裴蜀定理. 然后想一想的话就是 那么只要 ...
- 计算机网络传输层之TCP可靠传输
文章转自:https://blog.csdn.net/weixin_43914604/article/details/105524592 学习课程:<2019王道考研计算机网络> 学习目的 ...
- vim 让人爱不释手的编辑器之神
VIM 基本介绍 vim诞生已有20多年,它常被人称之为编辑器之神,vim的操作理念可以说是独具一格而又出类拔萃,使用vim能极大的提升文本处理效率,因此熟练掌握vim应该是每个程序员都应该做到的事情 ...
- Verdi Transaction Debug Mode 简单使用
转载:Verdi Transaction Debug Mode 简单使用_Holden_Liu的博客-CSDN博客 文档与源码: User Guide: Verdi_Transaction_and_P ...
- python中yield的理解
首先我要吐槽一下,看程序的过程中遇见了yield这个关键字,然后百度的时候,发现没有一个能简单的让我懂的,讲起来真TM的都是头头是道,什么参数,什么传递的,还口口声声说自己的教程是最简单的,最浅显易懂 ...
- 安装配置多个版本JDK
前言:JDK有多个版本,有时为了开发需要切换不同的版本,在一部电脑上安装多个JDK,只需要按以下配置,每次即可轻松使用.以下环境为Windows10 安装JDK 安装JDK8 配置环境变量 需要配置J ...
- Zabbix webhook 自定义报警媒介
场景一:使用企业微信机器人报警 图中的token是:在群组中添加机器人,机器人的webhook地址的key var Wechat = { token: null, to: null, message: ...