树形DP水题杂记
BZOJ1131: [POI2008]Sta
题意:给出一个N个点的树,找出一个点来,以这个点为根的树时,所有点的深度之和最大。
题解:记录每个点的深度,再根据根节点的深度和逐层推导出其他点的深度和。
我用的是BFS
#include <stdio.h>
#include <string.h>
#include <iostream>
#include <queue>
using namespace std;
typedef long long ll;
int n,cnt,ans;
int head[],next[],to[],fa[],s[];
ll f[],g[],siz[];
queue<int> q;
void add(int a,int b)
{
to[cnt]=b;
next[cnt]=head[a];
head[a]=cnt++;
}
int main()
{
scanf("%d",&n);
memset(head,-,sizeof(head));
int i,a,b,u;
for(i=;i<n;i++)
{
scanf("%d%d",&a,&b);
add(a,b);
add(b,a);
}
q.push();
while(!q.empty())
{
u=q.front();
q.pop();
s[++s[]]=u;
siz[u]++;
for(i=head[u];i!=-;i=next[i])
{
if(to[i]!=fa[u])
{
fa[to[i]]=u;
q.push(to[i]);
}
}
}
for(i=n;i>=;i--)
{
siz[fa[s[i]]]+=siz[s[i]];
f[fa[s[i]]]+=siz[s[i]]+f[s[i]]; //f[i]表示i的所有儿子到i的深度之和
}
g[]=f[ans=];
for(i=;i<=n;i++)
{
g[s[i]]=g[fa[s[i]]]+n-(siz[s[i]]<<); //g[i]表示所有点到i的距离之和,可由g[fa[i]]推出
if(g[ans]<g[s[i]]||(g[ans]==g[s[i]]&&ans>s[i]))
ans=s[i];
}
printf("%d",ans);
return ;
}
POJ3107:Godfather
题意:在树中找一个点,使去掉这个点后,剩余的所有子树节点个数的最大值最小,求满足要求的所有节点。
题解:求出每个子树的节点个数size[x],则答案为min(size[y],n-size[x]),y是x的儿子。
#include <stdio.h>
#include <string.h>
#include <iostream>
using namespace std;
const int maxn=;
int n,cnt,minn;
int head[maxn],to[maxn<<],next[maxn<<],s[maxn],f[maxn],sta[maxn];
int readin()
{
int ret=; char gc;
while(gc<''||gc>'') gc=getchar();
while(gc>=''&&gc<='') ret=ret*+gc-'',gc=getchar();
return ret;
}
void add(int a,int b)
{
to[cnt]=b;
next[cnt]=head[a];
head[a]=cnt++;
}
void dfs(int x,int fa)
{
s[x]=;
for(int i=head[x];i!=-;i=next[i])
{
if(to[i]!=fa)
{
dfs(to[i],x);
s[x]+=s[to[i]];
f[x]=max(f[x],s[to[i]]);
}
}
f[x]=max(f[x],n-s[x]);
minn=min(minn,f[x]);
}
int main()
{
n=readin();
memset(head,-,sizeof(head));
int i,a,b;
for(i=;i<n;i++)
{
a=readin(),b=readin();
add(a,b),add(b,a);
}
minn=<<;
dfs(,);
for(i=;i<=n;i++) if(f[i]==minn) sta[++sta[]]=i;
for(i=;i<sta[];i++) printf("%d ",sta[i]);
printf("%d",sta[sta[]]);
return ;
}
POJ1655:Balancing Act
题意:同POJ3107
#include <stdio.h>
#include <iostream>
#include <string.h>
using namespace std;
const int maxn=;
int n,minn,ans,cnt;
int s[maxn],to[maxn<<],next[maxn<<],head[maxn];
int readin()
{
int ret=; char gc;
while(gc<''||gc>'') gc=getchar();
while(gc>=''&&gc<='') ret=ret*+gc-'',gc=getchar();
return ret;
}
void add(int a,int b)
{
to[cnt]=b;
next[cnt]=head[a];
head[a]=cnt++;
}
void dfs(int x,int fa)
{
int t=;
s[x]=;
for(int i=head[x];i!=-;i=next[i])
{
if(to[i]!=fa)
{
dfs(to[i],x);
s[x]+=s[to[i]];
t=max(t,s[to[i]]);
}
}
t=max(t,n-s[x]);
if(t<minn||(t==minn&&x<ans)) ans=x,minn=t;
}
void work()
{
n=readin();
memset(head,-,sizeof(head));
ans=cnt=,minn=<<;
int i,a,b;
for(i=;i<n;i++)
{
a=readin(),b=readin();
add(a,b),add(b,a);
}
dfs(,);
printf("%d %d\n",ans,minn);
}
int main()
{
int t=readin();
while(t--) work();
return ;
}
BZOJ1827:[Usaco2010 Mar]gather 奶牛大集会
题意:与上一题差不多,只不过不同的点有不同的牛居住,求的是所有牛到核心的最小总路程
题解:见http://www.cnblogs.com/CQzhangyu/p/6178852.html
树形DP水题杂记的更多相关文章
- POJ 2342 &&HDU 1520 Anniversary party 树形DP 水题
一个公司的职员是分级制度的,所有员工刚好是一个树形结构,现在公司要举办一个聚会,邀请部分职员来参加. 要求: 1.为了聚会有趣,若邀请了一个职员,则该职员的直接上级(即父节点)和直接下级(即儿子节点) ...
- 树形DP水题系列(1):FAR-FarmCraft [POI2014][luogu P3574]
题目 大意: 边权为1 使遍历树时到每个节点的时间加上点权的最大值最小 求这个最小的最大值 思路: 最优化问题 一眼树形DP 考虑状态设立 先直接以答案为状态 dp[u] 为遍历完以u为根的子树的答案 ...
- ACM :漫漫上学路 -DP -水题
CSU 1772 漫漫上学路 Time Limit: 1000MS Memory Limit: 131072KB 64bit IO Format: %lld & %llu Submit ...
- [poj2247] Humble Numbers (DP水题)
DP 水题 Description A number whose only prime factors are 2,3,5 or 7 is called a humble number. The se ...
- POJ 1155 TELE 背包型树形DP 经典题
由电视台,中转站,和用户的电视组成的体系刚好是一棵树 n个节点,编号分别为1~n,1是电视台中心,2~n-m是中转站,n-m+1~n是用户,1为root 现在节点1准备转播一场比赛,已知从一个节点传送 ...
- POJ 2342 树形DP入门题
有一个大学的庆典晚会,想邀请一些在大学任职的人来參加,每一个人有自己的搞笑值,可是如今遇到一个问题就是假设两个人之间有直接的上下级关系,那么他们中仅仅能有一个来參加,求请来一部分人之后,搞笑值的最大是 ...
- Codeforces 148D 一袋老鼠 Bag of mice | 概率DP 水题
除非特别忙,我接下来会尽可能翻译我做的每道CF题的题面! Codeforces 148D 一袋老鼠 Bag of mice | 概率DP 水题 题面 胡小兔和司公子都认为对方是垃圾. 为了决出谁才是垃 ...
- 51nod 1353 树 | 树形DP经典题!
51nod 1353 树 | 树形DP好题! 题面 切断一棵树的任意条边,这棵树会变成一棵森林. 现要求森林中每棵树的节点个数不小于k,求有多少种切法. 数据范围:\(n \le 2000\). 题解 ...
- P2016 战略游戏——树形DP大水题
P2016 战略游戏 树形DP 入门题吧(现在怎么是蓝色标签搞不懂): 注意是看见每一条边而不是每一个点(因为这里错了好几次): #include<cstdio> #include< ...
随机推荐
- <jsp:include>和<%@include file=""%>区别【131031】
<jsp:include page=""> 父页面和包含进来的页面单独编译,单独翻译成servlet后,在前台拼成一个HTML页面. <%@include fil ...
- PHP+Nginx环境搭配
一.Nginx安装 nginx可以使用各平台的默认包来安装,本文是介绍使用源码编译安装,包括具体的编译参数信息. 正式开始前,编译环境gcc g++ 开发库之类的需要提前装好,这里默认你已经装好. u ...
- 连接SQL Server执行SQL语句
public static DataTable GetData() { string Connect = ConfigurationManager.AppSettings["Connecti ...
- STL Map的使用
Map是STL的一个关联容器,它提供一对一(其中第一个可以称为关键字,每个关键字只能在map中出现一次,第二个可能称为该关键字的值)的数据处理能力.下面就通过示例记录一下map的使用: 一.向map中 ...
- hdu 4753 2013南京赛区网络赛 记忆化搜索 ****
看到范围基本可以想到dp了,处理起来有点麻烦 #include<iostream> #include<cstdio> #include<cstring> #incl ...
- Node.js 究竟是什么?
Node.js 究竟是什么? 一个 "编码就绪" 服务器 Node 是一个服务器端 JavaScript 解释器,它将改变服务器应该如何工作的概念.它的目标是帮助程序员构建高度可伸 ...
- 10gRAC运行srvctl报错error while loading shared libraries:
数据库10g才会有这个错,因为11g的grid和oracle是分开的. [oracle@news01 orcl]$ srvctl /u01/app/oracle/db_1/jdk/jre/bin/ja ...
- 关于UltraISO打开iso文件后只有部分文件问题
背景:在安装CentOS 7的时候,用UltraISO打开之后,只有一个EFI文件,刻完U盘,却无法引导. 之前还以为偶没下载全,就又下了一遍,还好偶搞得的NetInstall,要不然就呵呵了. 解决 ...
- @property中strong跟weak的区别
strong关键字与retain关似,用了它,引用计数自动+1,用实例更能说明一切 @property (nonatomic, strong) NSString *string1; @property ...
- Android仿360手机卫士悬浮窗效果
请看下图: 首先是一个小的悬浮窗显示的是当前使用了百分之多少的内存,点击一下小悬浮窗,就会弹出一个大的悬浮窗,可以一键加速.好,我们现在就来模拟实现一下 ...