大数据算法课程笔记5a: fixed-parameter vertex cover

1. 问题描述

一个vertex cover是一个点集的集合,并且保证图中的每一条边都存在至少一个顶点位于该点集中。

具体地, G=(V,E) 的一个vertex cover S 满足

SV{e=(v,w)E,vS or wS}

fixed parameter vertex cover问题即寻找 |S|=k 的vertex cover。

2. 一个简单的算法

遍历 V 的所有可能子集,复杂度为O(|V|k)

3. FPT:Fixed Parameter Tractable

注意到上诉算法的fixed paramter位于 |V| 的指数项,所以我们无法说该算法是 |V| 的多项式算法。

定义FPT为复杂度为 O(f(k)nO(1)) 的算法。这个可以证明和 O(f(k)+nO(1)) 是等价的,其中 n 表示为问题的size/难度。

对于vertex cover问题,也存在FPT的算法,具体如下:

FPT

树的深度最多为k,所以最终算法复杂度为 O(|E|2k) ,或者 O(2k+|V|+|E|)

4. kernelization in fixed paramter complexity

所谓kernelization,是针对输入的一个预处理。通过一些限定条件,使得输入的大小变为一个和fixed parameter相关的更小的输入。

针对vertex cover问题,缩减的工作是通过删除所有度超过 k+1 的节点完成的。而重要的是缩减后的输入大小是节点数缩减为 k(k+1) ,因为vertex cover内部的点集数不超过 k ,而每个节点的度也不超过k,所以所有相连节点的数目不超过 k(k+1)

对于缩减后的输入应用以上算法都可以得到更好的结果。

至于所有度超过 k+1 的节点都位于 S 内,是使用反证法证明的。如果该点不在S内,则有其余超过 k+1 个点都必须在 S 中才能满足与该点相连的边被覆盖到,而|S|k

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值