题意即求一个最小顶点覆盖。

对于没有孤立点的图G=(V,E),最大独立集+最小顶点覆盖= V。(往最大独立集加点)

问题可以变成求树上的最大独立集合。

每个结点的选择和其父节点选不选有关,

dp(u,1)表示父节点选,这时u不可选,

dp(u,0)表示父节点不选,这时u可选可不选。

#include<bits/stdc++.h>
using namespace std; const int maxn = ;
int meo[maxn][];
int vis[maxn][], clk;
int hd[maxn],nx[maxn<<],to[maxn<<],ec; void add(int u,int v)
{
to[ec] = v;
nx[ec] = hd[u];
hd[u] = ec++;
} int dp(int u,int a = ,int f = -)//a表示父节点选不选
{
if(vis[u][a] == clk) return meo[u][a];
vis[u][a] = clk;
int &re = meo[u][a];
re = ;
int pick = ;
for(int i = hd[u]; ~i; i = nx[i]){
int v = to[i];
if(v == f) continue;
if(!a){
pick += dp(v,,u);
}
re += dp(v,,u);
}
if(!a) re = max(re,pick);
return re;
} //#define LOCAL
int main()
{
#ifdef LOCAL
freopen("in.txt","r",stdin);
#endif
int n;
while(~scanf("%d",&n)){
memset(hd,-,sizeof(hd)); ec = ;
for(int i = ; i < n; i++){
int u,sn; scanf("%d:(%d)",&u,&sn);
while(sn--){
int v;scanf("%d",&v);
add(u,v); add(v,u);
}
}
clk++;
printf("%d\n",n-dp());
}
return ;
}

最小点覆盖还可以用二分匹配来做

关键代码,下面可以适合无向图,如果用有向图的算法一个匹配会算两次。

int link[maxn];
int vis[maxn], clk; bool aug(int u)
{
if(vis[u] == clk) return false;
vis[u] = clk;
for(int i = hd[u]; ~i; i = nx[i]){
int v = to[i];
if(!~link[v] || aug(link[v])){
link[v] = u;
link[u] = v;
return true;
}
}
return false;
} int Hungary(int n)
{
memset(link,-,sizeof(link));
int ans = ;
for(int i = ; i < n; i++){
if(link[i]<){
clk++;
if(aug(i)) ans++;
}
}
return ans;
}

也可以直接dp求最小点覆盖集合,

f[u][p]表示以u为根的树最小点覆盖,p表示选不选u。

当选u的时候,子结点可选可不选,

当不选u的时候,子结点都选。

(实际上存在在某些结点只选一个子节点的最优解的情况,但是这样做并不会丢解)

int f[maxn][],vis[maxn],clk;

void dfs(int u = ,int fa = -)
{
vis[u] = clk;
f[u][] = ; f[u][] = ;
for(int i = hd[u]; ~i; i = nx[i]){
int v = to[i];
if(v == fa) continue;
if(vis[v] != clk) dfs(v,u);
f[u][] += min(f[v][],f[v][]);
f[u][] += f[v][];
}
}

LA 2038 Strategic game(最小点覆盖,树形dp,二分匹配)的更多相关文章

  1. HDU 1054 Strategic Game(最小点覆盖+树形dp)

    题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=106048#problem/B 题意:给出一些点相连,找出最小的点数覆盖所有的 ...

  2. HDU - 1054 Strategic Game(二分图最小点覆盖/树形dp)

    d.一颗树,选最少的点覆盖所有边 s. 1.可以转成二分图的最小点覆盖来做.不过转换后要把匹配数除以2,这个待细看. 2.也可以用树形dp c.匈牙利算法(邻接表,用vector实现): /* 用ST ...

  3. 两种解法-树形dp+二分+单调队列(或RMQ)-hdu-4123-Bob’s Race

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4123 题目大意: 给一棵树,n个节点,每条边有个权值,从每个点i出发有个不经过自己走过的点的最远距离 ...

  4. HDU1054 Strategic Game —— 最小点覆盖 or 树形DP

    题目链接:https://vjudge.net/problem/HDU-1054 Strategic Game Time Limit: 20000/10000 MS (Java/Others)     ...

  5. POJ1463 Strategic game (最小点覆盖 or 树dp)

    题目链接:http://poj.org/problem?id=1463 给你一棵树形图,问最少多少个点覆盖所有的边. 可以用树形dp做,任选一点,自底向上回溯更新. dp[i][0] 表示不选i点 覆 ...

  6. Strategic game(POJ 1463 树形DP)

    Strategic game Time Limit: 2000MS   Memory Limit: 10000K Total Submissions: 7490   Accepted: 3483 De ...

  7. HDU 1054 Strategic Game 最小点覆盖

     最小点覆盖概念:选取最小的点数覆盖二分图中的所有边. 最小点覆盖 = 最大匹配数. 证明:首先假设我们求的最大匹配数为m,那么最小点覆盖必然 >= m,因为仅仅是这m条边就至少需要m个点.然后 ...

  8. HDU 1054 Strategic Game (最小点覆盖)【二分图匹配】

    <题目链接> 题目大意:鲍勃喜欢玩电脑游戏,特别是战略游戏,但有时他无法找到解决方案,速度不够快,那么他很伤心.现在,他有以下的问题.他必须捍卫一个中世纪的城市,形成了树的道路.他把战士的 ...

  9. hdu 3586 Information Disturbing(树形dp + 二分)

    本文出自   http://blog.csdn.net/shuangde800 题目链接:   hdu-3586 题意 给一棵n个节点的树,节点编号为1-n,根节点为1.每条边有权值,砍掉一条边要花费 ...

随机推荐

  1. 【转载】【爬坑记录】hyperledger caliper 性能测试工具使用的一些问题记录

    原文: https://blog.csdn.net/raogeeg/article/details/82752613 安装方法详见:https://github.com/hyperledger/cal ...

  2. Codevs 1080 线段树练习(CDQ分治)

    1080 线段树练习  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond 题解       题目描述 Description 一行N个方格,开始每个格子里都有 ...

  3. return this链式操作

    function Fn(){}; Fn.prototype = { constructor:Fn, a:function(){ alert(1); return this; //实现链式操作.即fn. ...

  4. std::ref() 与 &

    引言 之前因为调整样式把博客园的样式毁了,所以一直在自己的另一个博客上更新,有兴趣的可以去观望一下:http://blog.yunlambert.top/最近还是把博客园拾起来吧..... 最近看到一 ...

  5. Luogu P3391 文艺平衡树(Splay or FHQ Treap)

    这道题要求区间反转...好东西.. 对于Splay:把l-1旋到根,把r+1旋到根的右儿子,这样r+1的左儿子就是整个区间了,然后对这个区间打个tg 注意要插-Inf和Inf到树里面,防止越界,坐标要 ...

  6. Spark (Python版) 零基础学习笔记(二)—— Spark Transformations总结及举例

    1. map(func) 将func函数作用到数据集的每个元素,生成一个新的分布式的数据集并返回 >>> a = sc.parallelize(('a', 'b', 'c')) &g ...

  7. Java面向对象_常用类库api

    StringBuffer 例: public class StringBufferDemo { /** * @param args */ public static void main(String[ ...

  8. Java面向对象_Object类

    Object类 是类层次结构的根类,每个类都是用Object类作为超类,所有对象(包括数组)都实现这个类的方法.所有类都是Object类的子类. 下面先说两个方法toString()和equals(O ...

  9. winform-Chrome-CefSharp库

    相关资源 教程地址:Winform下CefSharp的引用.配置.实例与报错排除 支持html5:http://www.html5tricks.com/demo/html5-css3-windmill ...

  10. 牛客网Java刷题知识点之匿名对象

    不多说,直接上干货! 匿名对象的两种用途: 1.当对象对方法仅进行一次调用的时候,就可以简化成匿名对象. 2.匿名对象可以作为实际参数进行传递. 匿名对象顾名思义就是没有名字的对象. new Car( ...