7.3 子集生成

7.3 子集生成

这一章主要介绍子集生成算法:给定一个集合,枚举出所有可能的子集。

首先提前在这里先声明一下,我们会依次学习三种子集生成的方法,但是书上这三种方法的代码都只是得到子集各个元素对应的下标组成的集合,而不是直接得到子集,所以如果需要得到子集还需要对书上的代码进行一系列的调整。


7.3.1 增量构造法

这个方法理解起来是真的非常困难,我参考了很多博客,才大概明白了个大概,代码如下:

#include<stdio.h>
//根据前面的经验我们显然可以知道这里的算法是通过递归实现的 
void print_subset(int n,int* A,int cur){
   
//说实话这里的cur我个人觉得写作len记作当前子集长度更好理解一点 
//由于排列生成和子集生成的区别,排列生成的长度锁定为n,于是递归的结束标示就是长度为n
//子集的长度为1-n中的任意长度,所以对于对于每一次函数,我们都需要一次打印 
	for (int i=0;i<cur;i++) printf("%d",A[i]);
	printf("\n"); int s=cur?A[cur-1]+1:0;
//主要是s这个式子确实搞,然后我想着递归的本质,就大概明白了一点
//就是说我们是通过递归将子集的长度从2到3到4进行递归
//假设递归到这里我们所获得的子集元素下标集合为{0,3,4},下标的最大值为7 
//那么我下一个元素的可能取值为1,2,5,6,7
//但是由于集合和我们之前的排列生成的区别在于,交换两个元素的位置,集合不发生改变
//于是可取的元素就是5-7,这里s=A[cur-1]+1,就是根据4得到了下一个元素
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值