P1041 集合的划分

P1041 集合的划分
描述
设S是一个具有n个元素的集合,S=〈a1,a2,……,an〉,现将S划分成k个满足下列条件的子集合S1,S2,……,Sk且满足:
1.Si≠∅
2.Si∩Sj=∅ (1≤i,j≤k,i≠j)
3.S1∪S2∪S3∪…∪Sk=S
则称S1,S2,……,Sk是集合S的一个划分。
它相当于把S集合中的n个元素a1,a2,……,an放入k个(0 < k ≤ n < 30)无标号的盒子中,使得没有一个盒子为空。请你确定n个元素a1,a2,……,an放入k个无标号盒子中去的划分数S(n,k)。
格式
输入格式
给出n和k。
输出格式
n个元素a1,a2,……,an放入k个无标号盒子中去的划分数S(n,k)。
样例
输入样例
10 6
输出样例
22827
限制
时间限制: 1000 ms
内存限制: 65536 KB

重点在这里的划分与总结

#include<stdio.h>
#include<iostream>
#include<string.h>
#include<algorithm>
using namespace std;
int sum=0;
long long  hua_fen(int n,int k)
{
    //要是元素的个数小于盒子的个数或者盒子的个数为0
    //其中元素的个数要是等于盒子的个数,就只有一种划分

    //盒子要是只有一个也只有一种划分
    //在每个盒子都装下了一个元素之后,

    //剩下来的每个元素中要分出来,元素{an}是不是k盒子中的一个,
    //若不是 则a1,...,an-1都是在k个盒子中的,而an此时有着k种方法
    //若是则需要把a1,...,an-1分到k-1个盒子中再把an加进去
    if(n<k||k==0)return 0;
    else if(n==k||k==1)return 1;
    else return k*hua_fen(n-1,k)+hua_fen(n-1,k-1);

}
int main()
{
   //集合的划分,其中的盒子是没有标号的,且不能一个盒子为空
   int n,k;
   cin>>n>>k;
   long long ans=hua_fen(n,k);
   cout<<ans<<endl;
   return 0;
}


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值