C++ 递归生成集合所有子集

问题描述:编写c++递归函数,输出n个元素的所有子集,例如三元素集{a,b,c}的子集是\oslash、{a}、{b}、{c}、

 {a,b},{a,c},{b,c},{a,b,c}。用0/1组成的代码序来表示分别是000,100,010,001,110,101,011,111(0表示

元素在子集中,1表示元素不在子集中)。因此程序只需要输出长度为n的0/1序列即可。

【问题参考:数据结构、算法与应用: C++语言描述 : 原书第2版[M]. 机械工业出版社, 2015. P29. 25题】

 

问题分析:如果我们要从集合中挑出子集,那么对集合中的每一个元素每次有选或不选两种方案,分别对应0

或是1,所有子集的数量共2^{n}个。具体的执行步骤是:先对集合中的第n个元素做决策(保留或抛弃),然后

然后再对剩下的n-1个元素做决策,直到决策次数累计有n次(递归终止条件)。具体代码如下


#include "stdafx.h"
#include<iostream>
using namespace std;

//递归函数 输出数组a(长度为len) 前n个元素的所有子集
//a[] 输入字符数组指针
// n  需要输出的前n个元素的所有子集
// len a的长度 
void Subset(char a[], int n, int len) {

	if (n == 0) {  // 递归终止条件

		for (int i = 0; i < len; i++) cout << a[i];
		cout << endl;
		delete[] a;  // 这里的a 就是temp
		return;
	}

	for (int j = 0; j <= 1; j++) { //每次需要做两种决策

		char *temp = new char[len];  
		
		for (int i = 0; i < len; i++) temp[i] = a[i];  //用临时数组来覆盖原来数组

		if (j == 0) { 
			temp[n - 1] = '0';
		}else {
			temp[n - 1] = '1'; 
		}
		Subset(temp, n - 1,len);
		
	}
	
}


int main()
{
	char a[3] = { 'a','b','c'};
	Subset(a, 3,3);
	char b;
	cin >> b; //保留窗体
    return 0;
}

程序运行结果如下:

为了更加直观地输出,我们还可以修改成如下的代码

for (int j = 0; j <= 1; j++) {
		char *temp = new char[len];
		
		for (int i = 0; i < len; i++) temp[i] = a[i];  

		if (j == 0) {          
			temp[n - 1] = '0';
		}  //去掉else 保留原始字符

		Subset(temp, n - 1,len);
		
}

对应输出结果

不足:程序递归过程中,temp指针只有在递归终点才被删除,因此会有内存泄漏的情况,大家有什么好的想法可以交流下。

  • 13
    点赞
  • 48
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值