码迷,mamicode.com
首页 > 其他好文 > 详细

Wannafly 锁

时间:2017-12-23 17:17:07      阅读:153      评论:0      收藏:0      [点我收藏+]

标签:等于   ann   大于等于   多少   post   解法   个人   题意   集合   

题意:

  现在有 $n$ 个人,每个人有一个已然给定的重要度 $a_i$,现有 K 个锁,每个锁有若干钥匙,分配给一些人,要求一群人能够打开全部 $K$ 把锁,

当且仅当他们重要度的和大于等于 $m$,问最少需要配备多少锁。

 

解法:

  定义极大人群集合为1~n这些人的一个子集,这个集合的人无法打开全部的锁,在这个集合任意添加一个人都能够打开所有的K个锁,这样,ans =  这样的集合个数。

  首先考虑对于一个极大集合S,必然是缺 K 种钥匙的其中几种的,如果我们假定是一种钥匙,这样有 [x 持有这种钥匙] = [x ? S](充要)。

  这样对于每一个极大集合都有一种钥匙来将极大集合内的元素和极大集合外的元素区分开,从而需要配备 cnt(S) 种钥匙。

  显然,这也是最少钥匙的方案。

 

Wannafly 锁

标签:等于   ann   大于等于   多少   post   解法   个人   题意   集合   

原文地址:http://www.cnblogs.com/lawyer/p/8093502.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!