Uva 6436 - The Busiest City 树形DP

原创 2013年12月01日 23:06:16

                 题意:

                           一棵树上有至多20000个点...现在问拆掉一个点..可以使得最多的两两不可达..输出最大的两两部可达..

                 题解:

                           只需统计以某点为根的子树节点数量..就可以推出每个点的答案了..找到最大的就是..而统计每个点做子树根节点数量..就是一个基本的树形DP...


Program:

#include <iostream>
#include <stdio.h>
#include <string.h>
#include <algorithm>
#define MAXN 20005
using namespace std;
struct node
{
       int v,next;
}edge[MAXN<<1];
int Ne,_next[MAXN],sum[MAXN],ans;
void addedge(int u,int v)
{
       edge[++Ne].next=_next[u],_next[u]=Ne;
       edge[Ne].v=v;
}
void dfs(int father,int u,int N)
{
       int k,v,m,temp;
       for (k=_next[u];k;k=edge[k].next)
       {
               v=edge[k].v;
               if (v==father) continue;
               dfs(u,v,N);
               sum[u]+=sum[v];
       }
       m=sum[u]*(N-1-sum[u]),temp=0;
       for (k=_next[u];k;k=edge[k].next)
       {
               v=edge[k].v;
               if (v==father) continue;
               temp+=sum[v]*(sum[u]-sum[v]);
       }
       m+=temp/2;
       ans=max(ans,m);
       sum[u]++;
}
int main()
{
       int C,cases,N,u,v,i; 
       scanf("%d",&C);
       for (cases=1;cases<=C;cases++)
       {
                scanf("%d",&N);
                Ne=0,memset(_next,0,sizeof(_next));
                for (i=1;i<N;i++)
                {
                        scanf("%d%d",&u,&v);
                        addedge(u,v),addedge(v,u);
                }
                ans=0;
                memset(sum,0,sizeof(sum));
                dfs(0,1,N);
                printf("Case #%d: %d\n",cases,ans);
       }
       return 0;
}


版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

UVA-6436 The Busiest City 树形DFS求解

给出n个顶点,n-1条边,对于每一个顶点来说每有一条路径经过,繁荣度+1,求最大繁荣度。 经过的含义就是这条路径使用了跟这个顶点相连的边中的的两条,任意组合都可以,所以要找出每个顶点相连的边延伸出去...

UVA 1220 Party at Hali-Bula (树形dp--树的最大独立集)

大体题意: 给你n 个人的上司和下属的关系,让你挑尽可能多的人来参加聚会,参加聚会的条件是 任意两个人不能具有直接的上司下属的关系,求最大人数? 思路: 树形dp  -- 树的最大独立集问题: ...

100道动态规划——37 UVA 1218 Perfect Service 树形DP 分析问题

树形DP         老实说一开始是考虑用点的个数减去最大独立集的点的个数,但是很快就发现不对,数据如下:         6         1 2         1 3      ...

UVA10253 - Series-Parallel Networks(树形DP+(组合) _ 建模很好)(好题)

题目链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&problem...

100道动态规划——36 UVA 1220 Party at Hali-Bula 树形DP 最大独立集 思考欠妥

题目的地址是:https://uva.onlinejudge.org/external/12/1220.pdf         pdf不是很好放上来就只给出链接了         好吧,这道题目我觉得...

Uva 10859 - Placing Lampposts 树形dp

Input: Standard In Output: Standard Out Next Generation Contest 1  Time Limit: 2 seconds ...
  • cyendra
  • cyendra
  • 2013年06月03日 15:56
  • 676

UVA 12186 Another Crisis [树形dp]

Another Crisis Time Limit: 3000MS 64bit IO Format: %lld & %lluA couple of years ago, a new...

UVA1220 树形DP

题意n个人,第一个人为老板,剩下n-1行,第一个字符串为员工名称,第二个字符串为上级名称。当选择上级的时候便不能再选择下级,求最多能选多少人,以及选择方案是否唯一。题解树的最大独立集问题。设d[u][...

uva1220Party at Hali-Bula(树形dp)

题目: Dear Contestant, I’m going to have a party at my villa at Hali-Bula to celebrate my retirement...
  • fouzhe
  • fouzhe
  • 2016年03月25日 01:04
  • 124

UVA 1218 带状态判断的树形Dp

刘汝佳在书上说了状态转移方程, 嗯是三道题中较难的就动手写了一下。。 发现有的状态是无效的, 就去看了刘汝佳的代码, 额使用极大值来表示。。 这里也可以特殊判断(比如我) -----用IMPOSS...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Uva 6436 - The Busiest City 树形DP
举报原因:
原因补充:

(最多只允许输入30个字)