【JZOJ3170】挑选玩具

这篇博客讨论了ABC如何从N个包含M种玩具的箱子中选择箱子,确保每种玩具至少出现一次的问题。文章分析了在2^m种选择情况下的O(2^m)枚举方法,并提出了通过分治策略计算方案数的优化技巧,最终得出答案的公式为:(sum (-1)^{|S|}2^{f[2m-S-1]})。

description

ABC找到N个箱子,箱子里装着一些玩具,一共有M种玩具,编号从1到M,同一种玩具可能出现在多个箱子里。

ABC决定从中选择一些箱子,把这些箱子中的玩具聚集到一起,必须保证每种玩具至少出现一次。

问ABC一共有多少种选择方案。


analysis

  • 对于2m2^m2m种玩具的选择情况,可以O(2m)O(2^m)O(2m)枚举哪些位没有玩具算答案

  • 哪些位没有玩具,相当于其他位都有玩具,本质上一样

  • f[S]f[S]f[S]表示选SSS集合玩具的方案数,那么f[2m−S−1]f[2^m-S-1]f[2mS1]表示不选SSS集合玩具的方案数

  • 对于分治求ff

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值