递归—集合划分

本文介绍了集合划分问题,提供了一种将n个元素放入k个无标号盒子的划分数S(n, k)的递归算法。通过递归公式S(n, k) = S(n - 1, k - 1) + k * S(n - 1, k) (n > k, k > 0),并给出边界条件,实现了一个C语言的递归函数来计算划分数。" 80749317,7336901,国内Top开源项目深度解读:协议、语言与社区趋势,"['开源项目', '编程语言', '开源协议', '开源文化', '社区协作']
摘要由CSDN通过智能技术生成

                                                                                          集合的划分
【问题描述】
       设S是一个具有n个元素的集合,S={a1,a2,……,an},现将S划分成k个满足下列条件的子集合S1,S2,……,Sk ,且满足:
              1.Si!=空
              2.Si 交 Sj = 空
              3.S1 U S2 U S3 U....U Sk = S
则称S1,S2,……,Sk是集合S的一个划分。它相当于把S集合中的n个元素a1 ,a2,……,an 放入k个(0<k≤n<30=无标号的盒子中,
使得没有一个盒子为空。请你确定n个元素a1 ,a2 ,……,an 放入k个无标号盒子中去的划分数S(n,k)。


【算法分析】
先举个例子,设S={1,2,3,4},k=3,不难得出S有6种不同的划分方案,即划分数S(4,3)=6,具体方案为:
{1,2}∪{3}∪{4}  {1,3}∪{2}∪{4}    {1,4

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值