LuoguP4383 [八省联考2018]林克卡特树lct
LuoguP4383 [八省联考2018]林克卡特树lct
https://www.luogu.org/problemnew/show/P4383
分析:
- 题意等价于选择\(K\)条点不相交的链,使得总路径长度和最大。
- 设\(f[x][i][0/1/2]\)表示\(x\)子树中选了\(i\)个,\(x\)的当前度数为\(0/1/2\)的答案。
- 然后我们感性理解一下可知,选\(k\)个点的方案,一定能够从\(k-1\)个点的方案中转移过来的,不会出现从\(k-i(i>1)\)上再选若干个不在\(k-1\)的方案中的链转移过来答案更优。
- 那么由于我们选择的链的权值是不断变小的,可知\(dp\)值是个凸函数,且单峰。
- 使用带权二分即可,对于本题,整数二分就可以通过。
代码:
// luogu-judger-enable-o2
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
#define N 300050
typedef long long ll;
const ll inf = 1ll<<60;
int head[N],to[N<<1],nxt[N<<1],cnt,val[N<<1],n,K,siz[N];
// ll f[N][105][3],tmp[105][3];
struct A {
ll x; int k;
A() {}
A(ll x_,int k_) {x=x_, k=k_;}
bool operator < (const A &u) const {
return x==u.x ? k>u.k : x<u.x;
}
A operator + (const A &u) const {
return A(x+u.x, k+u.k);
}
}f[N][3],ans,tmp[3];
inline void add(int u,int v,int w) {
to[++cnt]=v; nxt[cnt]=head[u]; head[u]=cnt; val[cnt]=w;
}
template<typename T>void chkmax(T &x,T y) {if(x<y)x=y;}
template<typename T>void chkmin(T &x,T y) {if(y<x)x=y;}
ll C;
// void dfs(int x,int y) {
// int i,j,k,p,q; siz[x]=1;
// memset(f[x],0xc0,sizeof(f[x]));
// f[x][0][0]=f[x][1][2]=0;
// for(i=head[x];i;i=nxt[i]) if(to[i]!=y) {
// dfs(to[i],x);
// for(j=0;j<=K&&j<=siz[x];j++) for(k=0;k<3;k++) tmp[j][k]=f[x][j][k], f[x][j][k]=-inf;
// int t=to[i],len=val[i];
// for(j=0;j<=K&&j<=siz[x];j++) {
// for(k=0;k<=K-j+1&&k<=siz[to[i]];k++) {
// //not choose
// for(p=0;p<3;p++) for(q=0;q<3;q++) chkmax(f[x][j+k][p],tmp[j][p]+f[t][k][q]);
// //choose
// chkmax(f[x][j+k+1][1],tmp[j][0]+f[t][k][0]+len);
// chkmax(f[x][j+k][1],tmp[j][0]+f[t][k][1]+len);
// chkmax(f[x][j+k][2],tmp[j][1]+f[t][k][0]+len);
// chkmax(f[x][j+k-1][2],tmp[j][1]+f[t][k][1]+len);
// }
// }
// siz[x]+=siz[to[i]];
// }
// }
void dfs(int x,int y) {
int i,p,q;
f[x][0]=A(0,0); f[x][1]=A(-inf,0); f[x][2]=A(C,1);
for(i=head[x];i;i=nxt[i]) if(to[i]!=y) {
int t=to[i];
dfs(to[i],x);
memcpy(tmp,f[x],sizeof(f[x]));
f[x][0]=f[x][1]=f[x][2]=A(-inf,0);
//not choose
for(p=0;p<3;p++) for(q=0;q<3;q++) chkmax(f[x][p],tmp[p]+f[t][q]);
chkmax(f[x][1],tmp[0]+f[t][0]+A(val[i]+C,1));
chkmax(f[x][1],tmp[0]+f[t][1]+A(val[i],0));
chkmax(f[x][2],tmp[1]+f[t][0]+A(val[i],0));
chkmax(f[x][2],tmp[1]+f[t][1]+A(val[i]-C,-1));
}
}
int main() {
scanf("%d%d",&n,&K);
K++;
int i,x,y,z;
for(i=1;i<n;i++) {
scanf("%d%d%d",&x,&y,&z);
add(x,y,z); add(y,x,z);
}
// dfs(1,0);
// printf("%lld\n",max(max(f[1][K][0],f[1][K][1]),f[1][K][2]));
ll l=-1e9, r=1e9;
while(l<r) {
ll mid=(l+r)>>1;
C=mid; dfs(1,0);
ans=max(max(f[1][0],f[1][1]),f[1][2]);
if(ans.k>K) r=mid;
else if(ans.k==K) {
printf("%lld\n",ans.x-K*C); return 0;
}
else l=mid+1;
}
l--;
C=l; dfs(1,0);
ans=max(max(f[1][0],f[1][1]),f[1][2]);
printf("%lld\n",ans.x-K*C);
}
LuoguP4383 [八省联考2018]林克卡特树lct的更多相关文章
- luoguP4383 [八省联考2018]林克卡特树(树上dp,wqs二分)
luoguP4383 [八省联考2018]林克卡特树(树上dp,wqs二分) Luogu 题解时间 $ k $ 条边权为 $ 0 $ 的边. 是的,边权为零. 转化成选正好 $ k+1 $ 条链. $ ...
- [八省联考2018]林克卡特树lct——WQS二分
[八省联考2018]林克卡特树lct 一看这种题就不是lct... 除了直径好拿分,别的都难做. 所以必须转化 突破口在于:连“0”边 对于k=0,我们求直径 k=1,对于(p,q)一定是从p出发,走 ...
- 洛谷P4383 [八省联考2018]林克卡特树lct(DP凸优化/wqs二分)
题目描述 小L 最近沉迷于塞尔达传说:荒野之息(The Legend of Zelda: Breath of The Wild)无法自拔,他尤其喜欢游戏中的迷你挑战. 游戏中有一个叫做“LCT” 的挑 ...
- [八省联考2018]林克卡特树lct
题解: zhcs的那个题基本上就是抄这个题的,不过背包的分数变成了70分.. 不过得分开来写..因为两个数组不能同时满足 背包的话就是 $f[i][j][0/1]$表示考虑i子树,取j条链,能不能向上 ...
- 洛谷 4383 [八省联考2018]林克卡特树lct——树形DP+带权二分
题目:https://www.luogu.org/problemnew/show/P4383 关于带权二分:https://www.cnblogs.com/flashhu/p/9480669.html ...
- 洛谷.4383.[八省联考2018]林克卡特树lct(树形DP 带权二分)
题目链接 \(Description\) 给定一棵边带权的树.求删掉K条边.再连上K条权为0的边后,新树的最大直径. \(n,K\leq3\times10^5\). \(Solution\) 题目可以 ...
- [BZOJ5252][八省联考2018]林克卡特树lct
bzoj(上面可以下数据) luogu description 在树上选出\(k\)条点不相交的链,求最大权值. 一个点也算是一条退化的链,其权值为\(0\). sol 别问我为什么现在才写这题 首先 ...
- P4383 [八省联考2018]林克卡特树lct
题目链接 题意分析 一句话题意就是 : 让你选出\((k+1)\)条不相交的链 使得这些链的边权总和最大 (这些链可以是点) 我们考虑使用树形\(DP\) \(dp[i][j][0/1/2]\)表示以 ...
- P4383 [八省联考2018]林克卡特树lct 树形DP+凸优化/带权二分
$ \color{#0066ff}{ 题目描述 }$ 小L 最近沉迷于塞尔达传说:荒野之息(The Legend of Zelda: Breath of The Wild)无法自拔,他尤其喜欢游戏中的 ...
随机推荐
- 开始翻译《Beginning SharePoint 2013 Development》
伙同涂曙光@kaneboy 和柴晓伟@WindieChai 翻译Beginning SharePoint 2013 Development 作者是Steve Fox,传说中的Andrew Connel ...
- Java程序发送邮件
之前上网有看到过别人总结的使用java程序发送邮件,于是自己下来练习,把自己学习的一些心得总结出来. 首先我们这里需要采用两个jar包: 需要的朋友可以自行上网去CSDN类似的网站上面找 顺便把自己测 ...
- IIS架构介绍
IIS7及以上版本提供的请求-处理架构包括以下内容: Windows Process Activation Service(WAS)可以让站点支持更多协议,不仅仅是HTTP和HTTPS 可以通过增加或 ...
- word2vec_basic.py
ssh://sci@192.168.67.128:22/usr/bin/python3 -u /home/win_pymine_clean/feature_wifi/word2vec_basic.py ...
- PHP开发环境搭建(转载)
转载自:http://blog.csdn.net/rosetta/article/details/53967215 前言 最近学了n种语言,学每种语言的套路无非就是先搭建一个开发环境,再找本书或者 ...
- Asp.Net 5 Web Hook
首先,然我们来看一下WebHooks是什么.WebHooks是一个协议.它们是HTTP回调技术.并且它们是"用户定义的HTTP回调".你和 (或) 您的应用程序在有什么事情发生时会 ...
- 8.Django模型类例子
这里定义4个模型 作者:一个作者有姓名 作者详情:包括性别,email,出生日期, 出版商:名称,地址,城市,省,国家,网站 书籍:名称,日期 分析: 作者详情和作者一对一的关系 一本书可以有多个作者 ...
- Django模型系统——ORM表结构对应关系
对于数据库来说一般表结构只会有三种对应关系,分别是一对一.一对多和多对一,下面分别介绍: 1.一对多 何为一对多,例如一个学生只可能有一个班级,一个班级却又多个学生,班级表和学生表就是一对多的关系. ...
- struts2核心和工作原理
转至:http://blog.csdn.net/laner0515/article/details/27692673 在学习struts2之前,首先我们要明白使用struts2的目的是什么?它能给我们 ...
- 阿里云 rails nginx 配置https访问
1.申请免费型dv ssl证书:https://common-buy.aliyun.com/?spm=a2c4e.11155515.0.0.7zzvOZ&commodityCode=cas#/ ...