(中等) HDU 5293 Tree chain problem,树链剖分+树形DP。
There are m chain on the tree, Each chain has a certain weight. Coco would like to pick out some chains any two of which do not share common vertices.
Find out the maximum sum of the weight Coco can pick
- // ━━━━━━神兽出没━━━━━━
- // ┏┓ ┏┓
- // ┏┛┻━━━━━━━┛┻┓
- // ┃ ┃
- // ┃ ━ ┃
- // ████━████ ┃
- // ┃ ┃
- // ┃ ┻ ┃
- // ┃ ┃
- // ┗━┓ ┏━┛
- // ┃ ┃
- // ┃ ┃
- // ┃ ┗━━━┓
- // ┃ ┣┓
- // ┃ ┏┛
- // ┗┓┓┏━━━━━┳┓┏┛
- // ┃┫┫ ┃┫┫
- // ┗┻┛ ┗┻┛
- //
- // ━━━━━━感觉萌萌哒━━━━━━
- // Author : WhyWhy
- // Created Time : 2015年07月22日 星期三 13时55分13秒
- // File Name : 1006.cpp
- #include <stdio.h>
- #include <string.h>
- #include <iostream>
- #include <algorithm>
- #include <vector>
- #include <queue>
- #include <set>
- #include <map>
- #include <string>
- #include <math.h>
- #include <stdlib.h>
- #include <time.h>
- #pragma comment(linker, "/STACK:1024000000,1024000000")
- using namespace std;
- const int MaxN=;
- struct Edge
- {
- int to,next;
- };
- struct Lian
- {
- int u,v;
- int cost;
- int next;
- };
- int N,M;
- Edge E[MaxN<<];
- int head[MaxN],Ecou;
- Lian L[MaxN];
- int Lhead[MaxN],Lcou;
- int fa[MaxN],dep[MaxN],son[MaxN],siz[MaxN],top[MaxN],w[MaxN];
- int Tcou;
- int C_max[MaxN],C_wu[MaxN];
- void init()
- {
- Ecou=;
- Lcou=;
- Tcou=;
- w[]=;
- top[]=;
- memset(Lhead,-,sizeof(Lhead));
- memset(head,-,sizeof(head));
- }
- void addEdge(int u,int v)
- {
- E[Ecou].to=v;
- E[Ecou].next=head[u];
- head[u]=Ecou++;
- }
- int lca(int a,int b)
- {
- while()
- {
- if(top[a]==top[b])
- return dep[a]<dep[b] ? a : b;
- else if(dep[top[a]]>dep[top[b]])
- a=fa[top[a]];
- else
- b=fa[top[b]];
- }
- }
- void addLian(int u,int v,int c)
- {
- int h=lca(u,v);
- L[Lcou].u=u;
- L[Lcou].v=v;
- L[Lcou].cost=c;
- L[Lcou].next=Lhead[h];
- Lhead[h]=Lcou++;
- }
- void dfs1(int u,int pre,int d)
- {
- int v;
- dep[u]=d;
- fa[u]=pre;
- siz[u]=;
- son[u]=-;
- for(int i=head[u];i!=-;i=E[i].next)
- if(E[i].to!=pre)
- {
- v=E[i].to;
- dfs1(v,u,d+);
- siz[u]+=siz[v];
- if(son[u]==- || siz[son[u]]<siz[v])
- son[u]=v;
- }
- }
- void dfs2(int u)
- {
- if(son[u]==-)
- return;
- top[son[u]]=top[u];
- w[son[u]]=++Tcou;
- dfs2(son[u]);
- int v;
- for(int i=head[u];i!=-;i=E[i].next)
- if(E[i].to!=son[u] && E[i].to!=fa[u])
- {
- v=E[i].to;
- top[v]=v;
- w[v]=++Tcou;
- dfs2(v);
- }
- }
- void TL_init()
- {
- dfs1(,-,);
- dfs2();
- memset(C_max,,sizeof(C_max));
- memset(C_wu,,sizeof(C_wu));
- }
- inline int lowbit(int x)
- {
- return x&(-x);
- }
- int sum(int x,int C[])
- {
- int ret=;
- while(x>)
- {
- ret+=C[x];
- x-=lowbit(x);
- }
- return ret;
- }
- void add(int x,int d,int C[])
- {
- while(x<=N)
- {
- C[x]+=d;
- x+=lowbit(x);
- }
- }
- int query(int u,int v,int C[])
- {
- int f1=top[u],f2=top[v];
- int ret=;
- while(f1!=f2)
- {
- if(dep[f1]<dep[f2])
- {
- swap(f1,f2);
- swap(u,v);
- }
- ret+=sum(w[u],C)-sum(w[f1]-,C);
- u=fa[f1];
- f1=top[u];
- }
- if(dep[u]>dep[v])
- swap(u,v);
- ret+=sum(w[v],C)-sum(w[u]-,C);
- return ret;
- }
- void update(int u,int ut,int C[])
- {
- add(w[u],ut,C);
- }
- int dp[MaxN][];
- void dfs(int u)
- {
- int v;
- int ans=;
- int maxn=,tsum1,tsum2;
- for(int i=head[u];i!=-;i=E[i].next)
- if(E[i].to!=fa[u])
- {
- dfs(E[i].to);
- ans+=dp[E[i].to][];
- }
- for(int h=Lhead[u];h!=-;h=L[h].next)
- {
- tsum1=query(L[h].u,L[h].v,C_wu);
- tsum2=query(L[h].u,L[h].v,C_max);
- maxn=max(maxn,tsum1-tsum2+ans+L[h].cost);
- }
- maxn=max(maxn,ans);
- dp[u][]=ans;
- dp[u][]=maxn;
- update(u,ans,C_wu);
- update(u,maxn,C_max);
- }
- int main()
- {
- //freopen("in.txt","r",stdin);
- //freopen("out.txt","w",stdout);
- int T;
- int a,b,c;
- scanf("%d",&T);
- while(T--)
- {
- scanf("%d %d",&N,&M);
- init();
- for(int i=;i<N;++i)
- {
- scanf("%d %d",&a,&b);
- addEdge(a,b);
- addEdge(b,a);
- }
- TL_init();
- while(M--)
- {
- scanf("%d %d %d",&a,&b,&c);
- addLian(a,b,c);
- }
- memset(dp,,sizeof(dp));
- dfs();
- printf("%d\n",dp[][]);
- }
- return ;
- }
(中等) HDU 5293 Tree chain problem,树链剖分+树形DP。的更多相关文章
- HDU 5293 Train chain Problem - 树链剖分(树状数组) + 线段树+ 树型dp
传送门 题目大意: 一颗n个点的树,给出m条链,第i条链的权值是\(w_i\),可以选择若干条不相交的链,求最大权值和. 题目分析: 树型dp: dp[u][0]表示不经过u节点,其子树的最优值,dp ...
- [HDU 5293]Tree chain problem(树形dp+树链剖分)
[HDU 5293]Tree chain problem(树形dp+树链剖分) 题面 在一棵树中,给出若干条链和链的权值,求选取不相交的链使得权值和最大. 分析 考虑树形dp,dp[x]表示以x为子树 ...
- HDU5293 树链剖分+树形DP
=-=抓住叶节点往上揪 Tree chain problem Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 65536/65536 K ...
- HDU 5293 Tree chain problem 树形dp+dfs序+树状数组+LCA
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5293 题意: 给你一些链,每条链都有自己的价值,求不相交不重合的链能够组成的最大价值. 题解: 树形 ...
- HDU 5293 Tree chain problem
树状数组 + dp 设$f_i$表示以$i$为根的子树中的能选取的最大和,$sum_x$表示$\sum_{f_y}$ ($y$是$x$的一个儿子),这样子我们把所有给出的链按照两点的$lca$分组, ...
- codeforces 671D Roads in Yusland & hdu 5293 Tree chain problem
dp dp优化 dfs序 线段树 算是一个套路.可以处理在树上取链的问题.
- HDU 5293 Tree chain problem 树形DP
题意: 给出一棵\(n\)个节点的树和\(m\)条链,每条链有一个权值. 从中选出若干条链,两两不相交,并且使得权值之和最大. 分析: 题解 #include <cstdio> #incl ...
- Water Tree CodeForces 343D 树链剖分+线段树
Water Tree CodeForces 343D 树链剖分+线段树 题意 给定一棵n个n-1条边的树,起初所有节点权值为0. 然后m个操作, 1 x:把x为根的子树的点的权值修改为1: 2 x:把 ...
- [POJ3237]Tree解题报告|树链剖分|边剖
关于边剖 之前做的大多是点剖,其实转换到边剖非常简单. 我的做法是每个点的点权记录其到父亲节点的边的边权. 只要solve的时候不要把最上面的点记录在内就可以了. Tree Description Y ...
随机推荐
- 在ASP.Net中"../" "./" "~/"表示的意思
"../" 相对当前(根据不同的语境,当前是不同的)的上一级目录"./" 就是当前目录 "~/" 当前项目的根路径,只在服务器端有效.
- 【同一直线最多点】 poj 1118+2606+2780
poj 1118 #include<iostream> using namespace std; #define N 700 struct point {int x,y;} pnt[N]; ...
- Cormen — The Best Friend Of a Man
Cormen — The Best Friend Of a Man time limit per test 1 second memory limit per test 256 megabytes i ...
- 初识Jmeter(一)
倒霉熊的推荐: 文本学习网址:http://m.open-open.com/m/doc/category/105 视频学习网址: 软件学习网:http://www.ask3.cn/index.html ...
- android下m、mm、mmm编译命令的使用
android下m.mm.mmm编译命令的使用 通过查看android源码目录下的build/envsetup.sh文件,可知: - m: Makes from the top of th ...
- javascript 总结学习一
1 , javascript字符集:javascript采用的是Unicode字符集编码.为什么要采用这个编码呢?原因很简单,16位的Unicode编码可以表示地球人的任何书面语言.这是语言 国际化的 ...
- 如何在使用eclipse的情况下,清理android项目中的冗余class文件和资源文件以及冗余图片
在我们迭代项目的过程中,经常会启用某些功能,或者修改某些界面的问题,那么问题来了,这样很容易出现大量的冗余.java文件,冗余资源文件,一些冗余的界面文件等.那么问题既然出现了,那么如何去解决呢,这就 ...
- Leetcode389
Find the Difference Given two strings s and t which consist of only lowercase letters. 给出两个字符串,s和t,都 ...
- Nginx代理外网映射
外网映射内网端口8080, 外网访问使用端口8379: nginx监听8080和80端口 #user nobody; worker_processes ; #error_log logs/error. ...
- 业务零影响!如何在Online环境中巧用MySQL传统复制技术【转】
业务零影响!如何在Online环境中巧用MySQL传统复制技术 这篇文章我并不会介绍如何部署一个MySQL复制环境或keepalived+双主环境,因为此类安装搭建的文章已经很多,大家也很熟悉.在这篇 ...