POJ 3585 Accumulation Degree】的更多相关文章

Accumulation Degree 大致题意:有一棵流量树,它的每一条边都有一个正流量,树上所有度数为一的节点都是出口,相应的树上每一个节点都有一个权值,它表示从这个节点向其他出口可以输送的最大总流量.我们的任务就是求这个最大总流量. \(solution:\) 这一道题需要仔细思考其性质,我们发现如果我们把某一个节点当做是这棵树的根,并求出了这一个点的权值,那么与它相连的节点我们也可以求出来.这是二次扫描和换根法的前提条件.现在我们详细的分析一下这一题的性质:如果我们现在有两个节点 $ i…
传送门:http://poj.org/problem?id=3585 题意:给定一张无根图,给定每条边的容量,随便取一点使得从这个点出发作为源点,发出的流量最大,并且输出这个最大的流量. 思路:最近开始做树形DP这部分的题,发现存图部分不是太会,这道题需要用到邻接表存图,不熟悉的朋友可以见我的另一篇博客:https://blog.csdn.net/weixin_43820920/article/details/98610704 言归正传,这道题算是换根DP的裸题了,就是先随便找一个点做为根结点(…
二次扫描与换根法 用于解决无根树,对于每一个节点作为根时都要统计 做法: 1.先以任意一个节点为根,做树形DP,保存每个节点的DP值 2.然后自上而下dfs,对于每个节点考虑以他为根的最大值 #include <iostream> #include <cstring> #include <cstdio> #include <algorithm> using namespace std; const int MAXN = 200505; int init()…
题面 一句话题意:找一个点使得,使得从这个点出发作为源点,发出的流量最大,输出这个最大的流量 这道题是换根法+二次扫描的模板: 首先若确定1为原点,那么可以写出dp方程:当v的度是1时, g[u]+=g[v];否则g[u]+=min(g[v],star[i].w); 但以上仅仅是有原点的做法,那么如果没有原点就只能是N^2了吗?当然不仅可能: 我们从上到下开始dfs,设f[i]表示以i为根所能得到的最大值,那么显然:f[1]=g[1]; 然后分两种情况:如果u的度是1,那么f[v]=g[u]+s…
Accumulation Degree Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 3425   Accepted: 859 题目链接:http://poj.org/problem?id=3585 Description: Trees are an important component of the natural landscape because of their prevention of erosion an…
Accumulation Degree Time Limit: 5000MS   Memory Limit: 65536K Total Submissions:3151   Accepted: 783 Description Trees are an important component of the natural landscape because of their prevention of erosion and the provision of a specific ather-sh…
题目:http://poj.org/problem?id=3585 很容易想出暴力.那么就先扫一遍. 然后得到了指定一个根后每个点的子树值. 怎么转化利用一下呢?要是能找出当前点的父亲的 “ 不含当前点的其他子树值 ” 就好了. 发现只需要把父亲的值减去 min ( 当前子树的值,该点与父亲间的边的值 ) 就行了!(因为当初这样加过) 需要注意一下的是叶节点.赋成INF或边的值都行. 特别需要注意的是第一次选的根节点在其余时候是叶节点的情况!!!!! #include<iostream> #i…
思路其实非常简单,借用一下最大流求法即可...默认以1为根时,$f[x]$表示以$x$为根的子树最大流.转移的话分两种情况,一种由叶子转移,一种由正常孩子转移,判断一下即可.换根的时候由頂向下递推转移,很容易得知推法(不说了.唯一需要注意的换根时原来度数为1的根转移为另一个子节点时,需要特判. RE记录:???poj玄学RE,手写_min带强制同类型转换才AC,用自带的就RE.嘛,,不管了.代码奇丑无比. #include<iostream> #include<cstdio> #i…
#include<cstdio> #include<cstring> #define INF 0x7fffffff using namespace std; ; inline int min(int a,int b){ return (a<b?a:b); } ],to[N*],c[N*],n; ; inline void add(int x,int y,int w){ edge_count++; to[edge_count]=y; c[edge_count]=w; next[…
题意:给出一棵树,边上有容量限制,求以任一点作为根和源点,叶子作为汇点的最大流的最大值 首先上网络流等于找死 树形DP可以\(O(n)\)求出以某点\(u\)为根的最大流,只需设\(f[u]=\sum min(cap_{u→v},f[v])\), 这是一个自底向上的过程 其中存在\(min\)是因为\(f[v]\)不包含连向\(u\)的边,要保证合法增广, 注意如果\(v\)为叶子则直接加上\(cap_{u→v}\) 此时我们也得知\(f[v]\)是以v为根的子树的最大流 那么换根后显然以\(v…