枚举子集复杂度 O(n^3) 证明

困扰多年的问题,居然在学习离散数学后的一分钟内得到解决。
形式化问题为,求满足 A ⊆ B ⊆ S A \sube B \sube S ABS 的有序对 < A , B > <A,B> <A,B> 的个数。

法1

类比子集数量的求法。每个元素有四种可能

  • 同时在 A A A B B B
  • A A A 不在 B B B
  • B B B 不在 A A A
  • 都不在

其中由题,在 A A A 不在 B B B 不符合题意,所以每个元素有三种可能,最后是 3 n 3^n 3n

法2

按照 A A A 中的元素个数 k k k 分类,对于一个固定的 k k k,有序对有 C ( n , k ) ⋅ 2 n − k C(n,k) \cdot 2^{n-k} C(n,k)2nk 个,其中 C ( n , k ) C(n,k) C(n,k) 表示先选出某个 A A A 2 n − k 2^{n-k} 2nk 表示在剩下的元素任选,使之包含 A A A

于是 N = ∑ k = 0 n C ( n , k ) ⋅ 2 n − k = ∑ k = 0 n C ( n , k ) ⋅ 1 k ⋅ 2 n − k = ( 1 + 2 ) n = 3 n N = \sum_{k=0}^{n} C(n,k)\cdot 2^{n-k} = \sum_{k=0}^{n} C(n,k)\cdot 1^k \cdot 2^{n-k} = (1+2)^n = 3^n N=k=0nC(n,k)2nk=k=0nC(n,k)1k2nk=(1+2)n=3n

反过来先选 B B B 也是一样的,即 C ( n , k ) ⋅ 1 n − k ⋅ 2 k C(n,k)\cdot 1^{n-k} \cdot 2^k C(n,k)1nk2k

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Jarden_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值