我是参考这一篇写的:http://blog.csdn.net/fsss_7/article/details/52049474

一点感想:dp[i][0]代表以这个点为根的且总叶子数为偶数个叶子的答案

考虑每条树边的贡献,贪心的想,肯定是每条树边出现的次数越少越好

由于树链肯定从一个叶子到另外一个叶子的,那么可以想到

1:考虑每条树边下面的子树,如果有奇数个节点,那么出来一条边就可以了,剩下的自己匹配就好

2:如果是偶数条边,出来两条就行了,如果多余两条不如两条更优,少于两条,不符合题意

dp[i][1]代表总点数为奇数时,以i为根的子树,包含一条链的最优答案

奇数比偶数实际上就多了,一条链,考虑包含这条链

贪心的想,这条链只要从一个叶子节点延伸到它的第一个祖先(且这个祖先的有大于一个儿子)就行了

dp[i][1]就是当前子树包含这条链的最优值,那么dp[root][1]就是奇数的答案,dp[root][0]就是偶数的答案

#include <cstdio>
#include <cstring>
#include <vector>
#include <queue>
#include <map>
#include <iostream>
#include <algorithm>
using namespace std;
typedef long long LL;
const int N=1e5+;
const int INF=0x3f3f3f3f;
int T,n,head[N],tot;
struct Edge{
int v,next;
}edge[N<<];
void add(int u,int v){
edge[tot].v=v;
edge[tot].next=head[u];
head[u]=tot++;
}
int d[N],son[N],dp[N][];
void dfs(int u,int f){
int child=;son[u]=;dp[u][]=;
for(int i=head[u];~i;i=edge[i].next){
int v=edge[i].v;if(v==f)continue;
dfs(v,u);++child;son[u]+=son[v];
dp[u][]+=dp[v][];
if(son[v]&)++dp[u][];
else dp[u][]+=;
}
for(int i=head[u];~i;i=edge[i].next){
int v=edge[i].v;if(v==f)continue;
if(child>&&son[v]==)
dp[u][]=min(dp[u][],dp[u][]);
if(dp[v][]==INF)continue;
int d = ((son[v] & ) ? : -);
dp[u][] = min(dp[u][], dp[u][] - dp[v][] + dp[v][] + d);
}
if(!child)son[u]=;
}
int main(){
scanf("%d",&T);
while(T--){
scanf("%d",&n);tot=;
memset(head,-,sizeof(head));
memset(dp,INF,sizeof(dp));
memset(d,,sizeof(d));
for(int i=;i<n;++i){
int u,v;scanf("%d %d",&u,&v);
add(u,v);add(v,u);++d[u];++d[v];
}
if(n==){printf("1\n");continue;}
int cnt=,root;
for(int i=;i<=n;++i)
if(d[i]!=)root=i;
else ++cnt;
dfs(root,);
if(cnt&)printf("%d\n",dp[root][]);
else printf("%d\n",dp[root][]);
}
return ;
}

HDU5758 Explorer Bo 树形dp的更多相关文章

  1. HDU5758 Explorer Bo 思维+树形dp

    题意自己看题目吧,挺短的. 思考过程:昨天感觉一天不做题很对不起自己,于是晚上跑到实验室打开别人树形dp的博客做了上面最后一个HDU的题,也是个多校题..一开始没有头绪了很久,因为起点不固定,所以这1 ...

  2. hdu5758 思维,树形dp

    /*可以推测从叶子结点传送到叶子节点才能使传送次数最少,如果是偶数个叶子结点,那么传送leaf/2次就是答案,如果是奇数个叶子结点,则还有单独一条链需要覆盖dp[u]表示覆盖完u为根的子树需要走的边数 ...

  3. 2016多校训练3_1007(hdu5758 Explorer Bo)

    #include <functional> #include <algorithm> #include <iostream> #include <iterat ...

  4. HDU 5758 Explorer Bo(树形DP)

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=5758 [题目大意] 给出一棵树,每条路长度为1,允许从一个节点传送到任意一个节点,现在要求在传送次 ...

  5. Day1:T3 bfs T4 树形DP

    T3:BFS 回看了一下Day1的T3...感觉裸裸的BFS,自己当时居然没有看出来... 同时用上升和下降两种状态bfs即可 这一题还要注意一个细节的地方,就是题目要求的是求往返的最优解 k=min ...

  6. poj3417 LCA + 树形dp

    Network Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 4478   Accepted: 1292 Descripti ...

  7. COGS 2532. [HZOI 2016]树之美 树形dp

    可以发现这道题的数据范围有些奇怪,为毛n辣么大,而k只有10 我们从树形dp的角度来考虑这个问题. 如果我们设f[x][k]表示与x距离为k的点的数量,那么我们可以O(1)回答一个询问 可是这样的话d ...

  8. 【BZOJ-4726】Sabota? 树形DP

    4726: [POI2017]Sabota? Time Limit: 20 Sec  Memory Limit: 128 MBSec  Special JudgeSubmit: 128  Solved ...

  9. 树形DP+DFS序+树状数组 HDOJ 5293 Tree chain problem(树链问题)

    题目链接 题意: 有n个点的一棵树.其中树上有m条已知的链,每条链有一个权值.从中选出任意个不相交的链使得链的权值和最大. 思路: 树形DP.设dp[i]表示i的子树下的最优权值和,sum[i]表示不 ...

随机推荐

  1. ios 关于StoryBoard 的简易使用说明

    ios 关于StoryBoard 的简易使用说明 http://www.tuicool.com/articles/FNRruy

  2. jvm调优具体参数配置

    3.JVM参数 在JVM启动参数中,可以设置跟内存.垃圾回收相关的一些参数设置,默认情况不做任何设置JVM会工作的很好,但对一些配置很好的Server和具体的应用必须仔细调优才能获得最佳性能.通过设置 ...

  3. Zookeeper安装部署

    Zookeeper安装 1. 安装 wget http://www.apache.org/dist//zookeeper/zookeeper-3.3.6/zookeeper-3.3.6.tar.gz ...

  4. 2014--9=17 软工二班 MyEclipse blue==1

    package cn.rwkj.test; import java.io.IOException; import java.net.ServerSocket; import java.net.Sock ...

  5. WCF入门(十一)---WCF安全

    一个强大的WCF服务安全系统,拥有两种安全模式或级别预期的客户端可以访问的服务.这是常见的分布式事务的安全威胁正在放缓,在很大程度上由WCF决定. 关键的安全功能 WCF服务有四个主要的安全功能,如下 ...

  6. OpenCV在Android平台上的应用

    今年8月份, OpenCV 2.3.1发布了. 虽然从2.2开始, OpenCV就号称支持Android平台, 但真正能让OpenCV在Android上运行起来还是在2.3.1版本上. 在这个版本上, ...

  7. 富有魅力的git stash

    git stash 会把当前的改动暂时搁置起来, 也就是所谓的git 暂存区. 你可以执行 git stash list 来查看你所有暂存的东东. 也可以 git stash apple ** 来拿下 ...

  8. 自定义View(3)关于canas.drawText

    本文以Canvas类的下面这个函数为基础,它用来在画布上绘制文本. public void drawText(String text, float x, float y, Paint paint) 效 ...

  9. Ionic开发中常见问题和解决方案记录

    1npm按装包失败 更换源:npm config set registry https://registry.npm.taobao.org 或者使用cnpm sudo npm install -g c ...

  10. bzoj4177: Mike的农场

    类似于最大权闭合图的思想. #include<cstdio> #include<cstring> #include<iostream> #include<al ...