原题等价于选择恰好$k+1$条不相交(无公共点)的路径使得边权和最大
证明:对于原题中的最优解,一定包含了k条0边权的边(否则可以将未使用的边删掉,然后将这条路径的末尾与不在同一个连通块内的点连边),那么选择这k条0边权的边所划分的$k+1$条路径即可;对于这$k+1$条路径,将每一条路径首尾连0边权的边,由于这些0边权的边和选择的边无法构成环,因此一定可以删除k条为选择的非0边使其变成一棵树,即原题中的操作
然后令$f(k)$表示选择了恰好k条路径的答案,那么有对于$\forall 1\le i<n$,都有$2f(i)\ge f(i-1)+f(i+1)$,即$f(i)-f(i-1)\ge f(i+1)-f(i)$
证明:建立一张费用流的图:S->i(1,0);i->i'(1,0);i'->T(1,0);i'->j(1,v(i,j))。容易发现$f(x)= 流量为x的最大费用$,由于费用流存在凸性,所以f也存在凸性
根据凸性二分即可,即二分$f(i)-f(i-1)\ge k$,考虑判定:将每条路径权值减去k并选择任意条路径使得权值和最大,那么最后即求出了$f(i)-ki$(特殊情况:$f(k+1)-f(k)=……=f(k+i)-f(k+i-1)$,那么只可以找到$f(k+i)$和$f(k)$,根据等式求出$f(k+1)$即可)
具体的树形dp:用$f[i][j=0/1/2]$表示以i为根的子树选择的端点包含i的边数j,转移分类讨论即可(注意:根据二分的过程,我们要选择尽量多的路径,因此还要记录对应的路径数量,可以用结构体来转移) 
 1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 300005
4 #define oo 1e12
5 #define ll long long
6 #define pli pair<ll,int>
7 #define fi first
8 #define se second
9 #define mx(k) max(f[k][0],max(f[k][1],f[k][2]))
10 int E,n,m,k,x,y,z,head[N];
11 pli o,f[N][3];
12 struct ji{
13 int nex,to,len;
14 }edge[N<<1];
15 pli add(pli x,pli y){
16 return make_pair(x.fi+y.fi,x.se+y.se);
17 }
18 void add(int x,int y,int z){
19 edge[E].nex=head[x];
20 edge[E].to=y;
21 edge[E].len=z;
22 head[x]=E++;
23 }
24 void dfs(int k,int fa,ll v){
25 f[k][0]=make_pair(0,0);
26 f[k][1]=f[k][2]=make_pair(-v,1);
27 for(int i=head[k];i!=-1;i=edge[i].nex)
28 if (edge[i].to!=fa){
29 int u=edge[i].to;
30 dfs(u,k,v);
31 memcpy(f[0],f[k],sizeof(f[0]));
32 for(int j=0;j<3;j++)f[k][j]=add(f[k][j],mx(u));
33 f[k][1]=max(f[k][1],add(add(f[0][0],f[u][1]),make_pair(edge[i].len,0)));
34 f[k][2]=max(f[k][2],add(add(f[0][1],f[u][1]),make_pair(edge[i].len+v,-1)));
35 }
36 }
37 pli pd(ll k){
38 dfs(1,0,k);
39 return mx(1);
40 }
41 int main(){
42 scanf("%d%d",&n,&m);
43 m++;
44 memset(head,-1,sizeof(head));
45 for(int i=1;i<n;i++){
46 scanf("%d%d%d",&x,&y,&z);
47 add(x,y,z);
48 add(y,x,z);
49 }
50 ll l=-oo,r=oo;
51 while (l<r){
52 ll mid=(l+r+1>>1);
53 if (pd(mid).se>=m)l=mid;
54 else r=mid-1;
55 }
56 o=pd(l-1);
57 printf("%lld",o.fi+o.se*(l-1)+l*(m-o.se));
58 }

[loj2478]林克卡特树的更多相关文章

  1. [八省联考2018]林克卡特树lct——WQS二分

    [八省联考2018]林克卡特树lct 一看这种题就不是lct... 除了直径好拿分,别的都难做. 所以必须转化 突破口在于:连“0”边 对于k=0,我们求直径 k=1,对于(p,q)一定是从p出发,走 ...

  2. [BZOJ 5252][LOJ 2478][九省联考2018] 林克卡特树

    [BZOJ 5252][LOJ 2478][九省联考2018] 林克卡特树 题意 给定一个 \(n\) 个点边带权的无根树, 要求切断其中恰好 \(k\) 条边再连 \(k\) 条边权为 \(0\) ...

  3. 【BZOJ5252】林克卡特树(动态规划,凸优化)

    [BZOJ5252]林克卡特树(动态规划,凸优化) 题面 BZOJ(交不了) 洛谷 题解 这个东西显然是随着断开的越来越多,收益增长速度渐渐放慢. 所以可以凸优化. 考虑一个和\(k\)相关的\(dp ...

  4. LuoguP4383 [八省联考2018]林克卡特树lct

    LuoguP4383 [八省联考2018]林克卡特树lct https://www.luogu.org/problemnew/show/P4383 分析: 题意等价于选择\(K\)条点不相交的链,使得 ...

  5. P4383 [八省联考2018]林克卡特树 树形dp Wqs二分

    LINK:林克卡特树 作为树形dp 这道题已经属于不容易的级别了. 套上了Wqs二分 (反而更简单了 大雾 容易想到还是对树进行联通情况的dp 然后最后结果总和为各个联通块内的直径. \(f_{i,j ...

  6. luoguP4383 [八省联考2018]林克卡特树(树上dp,wqs二分)

    luoguP4383 [八省联考2018]林克卡特树(树上dp,wqs二分) Luogu 题解时间 $ k $ 条边权为 $ 0 $ 的边. 是的,边权为零. 转化成选正好 $ k+1 $ 条链. $ ...

  7. 【HEOI 2018】Day2 T2 林克卡特树

    题目大意: 给一个n个节点的树,然后将其分成k+1个联通块,再在每个联通块取一条路径,将其连接起来,求连接起来的路径最大权值. 题解: 考场只会20分,还都打挂了…… 60分的做法其实并不难,nk D ...

  8. bzoj5252 [2018多省省队联测]林克卡特树

    斜率优化树形dp?? 我们先将问题转化成在树上选K+1条互不相交路径,使其权值和最大. 然后我们考虑60分的dp,直接维护每个点子树内选了几条路径,然后该点和0/1/2条路径相连 然后我们会发现最后的 ...

  9. BZOJ5252 八省联考2018林克卡特树(动态规划+wqs二分)

    假设已经linkcut完了树,答案显然是树的直径.那么考虑这条直径在原树中是怎样的.容易想到其是由原树中恰好k+1条点不相交的链(包括单个点)拼接而成的.因为这样的链显然可以通过linkcut拼接起来 ...

随机推荐

  1. 高德 Serverless 平台建设及实践

    作者 | 邓学祥(祥翼) 来源 | Serverless 公众号 高德从 FY21 财年开始启动 Serverless 建设,至今一年了,高德 Serverless 业务的峰值超过十万 qps 量级, ...

  2. Git学习笔记02-配置

    安装好Git之后,做的就是需要配置Git了 第一步,配置自己的名称和邮箱 打开Git Bash 输入命令 git config --global user.name "用户名" g ...

  3. Java语言程序设计与数据结构(基础篇)第七章答案

    答案为本人求解,如有错误,还望海涵.如有雷同,纯属巧合. 7.1 import java.util.Scanner; public class Main { public static void ma ...

  4. 简单几步零成本使用Vercel部署OneIndex 无需服务器搭建基于OneDrive的网盘

    前提 你需要一个OneDrive账号,必须管理员开放API 需要已安装Node.js 拥有Github账号,没有就注册一个 魔法上网环境(看情况) 注册应用 登录https://portal.azur ...

  5. Mybatis初始化机制

    对于任何框架而言,在使用前都要进行一系列的初始化,MyBatis也不例外.本章将通过以下几点详细介绍MyBatis的初始化过程. 1.MyBatis的初始化做了什么 2. MyBatis基于XML配置 ...

  6. 关于 我的博客和Git-hub

    欢迎大家到我的GitHub 热烈讨论 https://github.com/ljj-19951010 由于另一个博客忘了怎么登陆了,换用此博客(仅供个人学习使用,请勿传播) 如果想看 特别详细的教程请 ...

  7. T-SQL——关于XML类型

    目录 0. 将结果集转化为XML格式 1. 列值拼接为字符串 2. 字符串转换为列值 3. 一些说明 参考 志铭-2021年10月23日 10:43:21 0. 将结果集转化为XML格式 测试数据 I ...

  8. Redis:学习笔记-01

    Redis:学习笔记-01 该部分内容,参考了 bilibili 上讲解 Redis 中,观看数最多的课程 Redis最新超详细版教程通俗易懂,来自 UP主 遇见狂神说 1. Redis入门 2.1 ...

  9. [no_code][Alpha]项目展示博客

    $( "#cnblogs_post_body" ).catalog() 团队项目链接 github 后端 github OCR文档-含部分所需测试代码目前private API调用 ...

  10. [Beta]the Agiles Scrum Meeting 1

    会议时间:2020.5.9 21:00 1.每个人的工作 今天已完成的工作 讨论转会事项 经过组内成员的讨论,我们做出了非常艰难的决定:我们的组员老c将作为转会成员,离开我们的团队.感谢老c在Alph ...