NP完全问题 8.9

8.9. In the Hitting Set Problem, we are given a family of sets {S1,S2,…,Sn), and a budget b, and we wish to find a set H of size <= b which intersects every Si,if such an H exists ,In other words, we want H∩Si != ∅ for all i,show that Hitting Set is NP-complete.

image_1c2ophsn43nhsq5qe2178h11mk9.png-126.9kB

证明:

1. 证明该问题是一个NP问题

给出一个确定的集合H,我们可以很容易的用多项式时间去验证,H是否与每一个Si相交,因此是NP问题

2. 证明该问题是一个NP-hard问题

我们用最小顶点覆盖问题来归约碰撞集问题,因为我们已知最小顶点覆盖是一个NP-hard问题
给定一个图G = (V,E),Si即为G中的边,Si = {v1, V2}为这条边的两个顶点,一个图G的最小顶点覆盖即找到一个最小的顶点集,使得所有在图中的边,都被这些顶点说包含的边所覆盖。这个顶点集就是H,若找不出该顶点覆盖来触及每一条边,则意味着不存在这样一个H与每一个集合Si相交,若顶点覆盖的顶点数大于b,则意味着H的规模也会大于b,因此是NP-hard问题

3. 证明该问题是一个NP-complete问题

因为碰撞集问题是一个NP问题,还是一个NP-hard问题,根据对NP-complete的定义,碰撞集是一个NP完全问题

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值