[loj2478]林克卡特树
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]林克卡特树的更多相关文章
- [八省联考2018]林克卡特树lct——WQS二分
		[八省联考2018]林克卡特树lct 一看这种题就不是lct... 除了直径好拿分,别的都难做. 所以必须转化 突破口在于:连“0”边 对于k=0,我们求直径 k=1,对于(p,q)一定是从p出发,走 ... 
- [BZOJ 5252][LOJ 2478][九省联考2018] 林克卡特树
		[BZOJ 5252][LOJ 2478][九省联考2018] 林克卡特树 题意 给定一个 \(n\) 个点边带权的无根树, 要求切断其中恰好 \(k\) 条边再连 \(k\) 条边权为 \(0\) ... 
- 【BZOJ5252】林克卡特树(动态规划,凸优化)
		[BZOJ5252]林克卡特树(动态规划,凸优化) 题面 BZOJ(交不了) 洛谷 题解 这个东西显然是随着断开的越来越多,收益增长速度渐渐放慢. 所以可以凸优化. 考虑一个和\(k\)相关的\(dp ... 
- LuoguP4383 [八省联考2018]林克卡特树lct
		LuoguP4383 [八省联考2018]林克卡特树lct https://www.luogu.org/problemnew/show/P4383 分析: 题意等价于选择\(K\)条点不相交的链,使得 ... 
- P4383 [八省联考2018]林克卡特树 树形dp Wqs二分
		LINK:林克卡特树 作为树形dp 这道题已经属于不容易的级别了. 套上了Wqs二分 (反而更简单了 大雾 容易想到还是对树进行联通情况的dp 然后最后结果总和为各个联通块内的直径. \(f_{i,j ... 
- luoguP4383 [八省联考2018]林克卡特树(树上dp,wqs二分)
		luoguP4383 [八省联考2018]林克卡特树(树上dp,wqs二分) Luogu 题解时间 $ k $ 条边权为 $ 0 $ 的边. 是的,边权为零. 转化成选正好 $ k+1 $ 条链. $ ... 
- 【HEOI 2018】Day2 T2 林克卡特树
		题目大意: 给一个n个节点的树,然后将其分成k+1个联通块,再在每个联通块取一条路径,将其连接起来,求连接起来的路径最大权值. 题解: 考场只会20分,还都打挂了…… 60分的做法其实并不难,nk D ... 
- bzoj5252 [2018多省省队联测]林克卡特树
		斜率优化树形dp?? 我们先将问题转化成在树上选K+1条互不相交路径,使其权值和最大. 然后我们考虑60分的dp,直接维护每个点子树内选了几条路径,然后该点和0/1/2条路径相连 然后我们会发现最后的 ... 
- BZOJ5252 八省联考2018林克卡特树(动态规划+wqs二分)
		假设已经linkcut完了树,答案显然是树的直径.那么考虑这条直径在原树中是怎样的.容易想到其是由原树中恰好k+1条点不相交的链(包括单个点)拼接而成的.因为这样的链显然可以通过linkcut拼接起来 ... 
随机推荐
- 前端必会的Javascript经典面试题
			这是前端最基础的问题,也是在面试中难倒无数同学的经典问题 01. Javascript 数据类型 Javascript 数据类型 = 基本类型 + 引用类型 ES6 之前 5 + 1 = 6 种 ES ... 
- mysql join语句的执行流程是怎么样的
			mysql join语句的执行流程是怎么样的 join语句是使用十分频繁的sql语句,同样结果的join语句,写法不同会有非常大的性能差距. select * from t1 straight_joi ... 
- NXOpen.BlockStyler的一些用法
			关于BLOCK UI的一些控件的用法,本人曾经使用的代码,拿出来共享: Option Strict Off Imports NXOpen Imports NXOpen.BlockStyler Impo ... 
- 《手把手教你》系列技巧篇(三十四)-java+ selenium自动化测试-单选和多选按钮操作-中篇(详解教程)
			1.简介 今天这一篇宏哥主要是讲解一下,如何使用list容器来遍历单选按钮.大致两部分内容:一部分是宏哥在本地弄的一个小demo,另一部分,宏哥是利用JQueryUI网站里的单选按钮进行实战. 2.d ... 
- [no code][scrum meeting] Alpha 4
			项目 内容 会议时间 2020-04-09 会议主题 OCR相关的技术展示与讨论 会议时长 30min 参会人员 全体成员 $( "#cnblogs_post_body" ).ca ... 
- C语言链表实例--玩转链表
			下图为最一简单链表的示意图: 第 0 个结点称为头结点,它存放有第一个结点的首地址,它没有数据,只是一个指针变量.以下的每个结点都分为两个域,一个是数据域,存放各种实际的数据,如学号 num,姓名 n ... 
- Luogu P3758 [TJOI2017]可乐 | 矩阵乘法
			题目链接 让我们先来思考一个问题,在一张包含$n$个点的图上,如何求走两步后从任意一点$i$到任意一点$j$的方案数. 我们用$F_p(i,j)$来表示走$p$步后从$i$到$j$的方案数,如果存储原 ... 
- Luogu P1023 [NOIp2000提高组]税收与补贴问题 | 数学
			题目链接 思路:列不等式组,然后解出不等式,得出答案的取值范围,最后取一个绝对值最小的答案就行了. #include<iostream> #include<cstdio> #i ... 
- hdu 5172 GTY's gay friends(线段树最值)
			题意: GTY有n个朋友,站成一排,每个人有一个特征值ai. 有m个询问.每次询问给两个数L,R.问你[L,R](即aL...aR)是否是1..(R-L+1)的一个全排列. 是输出YES,否则输出NO ... 
- 『学了就忘』Linux基础 — 16、Linux系统与Windows系统的不同
			目录 1.Linux严格区分大小写 2.Linux一切皆文件 3.Linux不靠扩展名区分文件类型 4.Linux中所有的存储设备都必须在挂载之后才能使用 5.Windows下的程序不能直接在Linu ... 
