subset子集全排序问题
思路一
可以用递推的思想,观察S=[], S =[1], S = [1, 2] 时解的变化。

可以发现S=[1, 2] 的解就是 把S = [1]的所有解末尾添上2,然后再并上S = [1]里面的原有解。因此可以定义vector<vector<int> > 作为返回结果res, 开始时res里什么都没有,第一步放入一个空的vecotr<int>,然后这样迭代n次,每次更新res 内容,最后返回res。
#include<iostream>
#include<vector>
using namespace std; void subset1(int *a, int n)
{
vector<vector<int>> sub(1);// (pow(2, n) + 1);
//这种初始化方式是直接插入了1个为空的元素。此时sub.size()是1。
//扩展容量用resize,提高性能
sub.reserve(pow(2, n) + 1);
for (int i = 0; i < n; ++i)
{
int len = sub.size();
for (int j = 0; j < len; ++j)
{
auto temp = sub[j];
temp.push_back(a[i]);
sub.push_back(temp);
}
}
for (int i = 0; i < sub.size(); ++i)
{
for (int j = 0; j < sub[i].size(); ++j)
{
cout << sub[i][j];
}
cout << endl;
}
}
int main()
{
int a[] = { 1,2,3,4 };
subset1(a, 4);
}
结果 第一个空行代表空集。
1
2
12
3
13
23
123
4
14
24
124
34
134
234
1234
请按任意键继续. . .
思路二
所谓子集,就是包含原集合中的一些元素,不包含另一些元素。如果单独看某一个元素,它都有两种选择:"被包含在子集中"和"不被包含在子集中",对于元素个数为n、且不含重复元素的S,子集总数是2n。因此我们可以遍历S的所有元素,然后用递归考虑每一个元素包含和不包含的两种情况。
代码,这种思路需要用到递归
#include<iostream>
#include<vector>
using namespace std; static vector<vector<int>> sub2;
void subset2(int *a, int n, int t, vector<int> temp)
{
if (t == n)
{
sub2.push_back(temp);
return;
}
subset2(a, n, t + 1, temp);
temp.push_back(a[t]);
subset2(a, n, t + 1, temp);
} int main()
{
int a[] = { 1,2,3,4 };
vector<int> temp; subset2(a, 4, 0, temp);
for (int i = 0; i < sub2.size(); ++i)
{
for (int j = 0; j < sub2[i].size(); ++j)
cout << sub2[i][j];
cout << endl;
}
}
结果 第一个空行代表空集。
4
3
34
2
24
23
234
1
14
13
134
12
124
123
1234
请按任意键继续. . .
思路三
用一个unsigned int 的每个bit位来表示子集的每一个元素的两种情况。前提 原集合中不含重复字符。(含有的话,会出现重复)
#include<iostream>
#include<vector>
using namespace std; static vector<vector<int>> sub2;
void subset3(int *a, int n)
{
unsigned int num = 1 << n;
cout << num << endl;
for (unsigned int i = 0; i < num; ++i)
{
unsigned int q = i;
for (int j = 0; j < n; ++j,q>>=1)
{
if (q & unsigned int ( 1))
{
cout <<a[j];
}
}
cout << endl;
}
} int main()
{
int a[] = { 1,2,3,4 };
subset3(a, 4);
}
结果 第二个空行代表空集。
16 1
2
12
3
13
23
123
4
14
24
124
34
134
234
1234
请按任意键继续. . .
vector<int> temp2 = temp;
subset2(a, n, sum, t, f + 1, temp);//当前的不包含
temp.push_back(a[f]);
subset2(a, n, sum, t +a[f], f,temp);//可重复的重点
temp2.push_back(a[f + 1]);
subset2(a, n, sum, t + a[f+1],f+1, temp2);//当前的包含
元素可重复,求子集的元素和为一个常数
#include<iostream>
#include<vector>
#include<set>
using namespace std; static set<vector<int>> sub2;//去重
//a是数组,n数组个数,sum一开始就是0,t是要求的和,f一开始是0
void subset2(int *a, int n,int sum, int t, int f,vector<int> temp)
{
if (t > sum)
return;
if (t == sum)
{
sub2.insert(temp);
return;
}
if (f == n)return;
vector<int> temp2 = temp;
subset2(a, n, sum, t, f + 1, temp);
temp.push_back(a[f]);
subset2(a, n, sum, t +a[f], f,temp);
temp2.push_back(a[f + 1]);
subset2(a, n, sum, t + a[f+1],f+1, temp2); } int main()
{
int a[] = { 4,1,3,2};
vector<int> temp;
subset2(a, 4,7,0,0, temp);
for (auto p = sub2.begin(); p != sub2.end(); ++p)
{
for (int j = 0; j < (*p).size(); ++j)
cout << (*p)[j];
cout << endl;
}
}
结果:和为7
1111111
111112
11113
11122
1132
1222
133
322
4111
412
43
请按任意键继续. . .
subset子集全排序问题的更多相关文章
- R语言︱排序问题
		每每以为攀得众山小,可.每每又切实来到起点,大牛们,缓缓脚步来俺笔记葩分享一下吧,please~ --------------------------- 数据排序 1.sort(),rank(),or ... 
- 第K大子集-LH
		题解:搜索+二分 对于每个数有选与不选两种情况.然后我们先搜前一半的状态,每个数选还是不选. 有2^17种,然后我将每种状态拍一个序先存着.然后我再搜后一半的状态,2^18种. 假设后一半某一种情况的 ... 
- CSDN-Markdown语法集锦
		前言: 使用Markdown近一个来月.越来越认为不舒爽. 改字体.改字号.改颜色.改样式,全不会!想加个数学公式.得,仅仅会截图.把图片传上去了还不会控制大小.也不会控制文字与图片的排版,写出来的博 ... 
- Player Settings 导出设置
		Player Settings is where you define various parameters (platform specific) for the final game that y ... 
- 播放器设置 Player Settings
		原地址:http://game.ceeger.com/Manual/class-PlayerSettings.html#Android Player Settings is where you def ... 
- Unity导包配置详解
		Player Settings is where you define various parameters (platform specific) for the final game that y ... 
- words2
		餐具:coffee pot 咖啡壶coffee cup 咖啡杯paper towel 纸巾napkin 餐巾table cloth 桌布tea -pot 茶壶tea set 茶具tea tray 茶盘 ... 
- 2019-8-31-Latex-公式速查
		title author date CreateTime categories Latex 公式速查 lindexi 2019-08-31 16:55:58 +0800 2018-05-25 16:5 ... 
- Latex 公式速查
		本文记录了一些常用的数学公式对应的 Latex 字符,用于快速查找需要的字符 所有的在 Latex 使用的字符公式,都需要放在\(和\),$ 和 $,\begin{math} 和\end{math}之 ... 
随机推荐
- 小程序中WXSS样式控制
			WXSS WXSS(WeiXin Style Sheets)是一套样式语言,用于描述 WXML 的组件样式. WXSS 用来决定 WXML 的组件应该怎么显示. 为了适应广大的前端开发者,WXSS 具 ... 
- String to Integer (atoi) ???
			#define INT_MAX 2147483647 #define INT_MIN -2147483648 class Solution { public: int atoi(const char ... 
- hbase集群配置
			说明 安装 配置 启动 网页效果 一点废话 本文介绍hbase集群配置 说明 hbase想正确配置成功的前提是,你必须知道hadoop集群和zookeeper集群是如何配置的 安装 下载地址 http ... 
- Android Eclipse调试技巧
			在Android 应用程序开发中我们经常需要调试程序,可以说调试在我们的日常开发中起着十分重要的作用,下面就以Elipse开发环境总结一下调试技巧. 一.Debug 断点调试 所谓断点调试就是指在程序 ... 
- java事件监听机制2
			今天早上的两点收获: 1.addActionListener(其中的setActionCommand函数就是要对对象进行唯一性的标记,便于消息传来后进行处理.理论上actionlistener可以全部 ... 
- LeetCode题解 #2 Add Two Numbers
			题目大意:使用链表表示的两个整数,计算出其和,以同样的形式返回. Input: (2 -> 4 -> 3) + (5 -> 6 -> 4) Output: 7 -> 0 ... 
- 安装sshpass:No package sshpass available
			安装sshpass的时候,报了如下错误: No Package sshpass available 更改软件源之后也无效.直到看到StackOverFlow上的一个问题:https://stackov ... 
- 【HDU4303】Hourai Jeweled
			题意 有一棵n个结点的树,每个结点都有一个值,没一条边都有一个颜色.如果某条路径上,相邻的边颜色不同,那么把这路径上所有的点的值加起来. 输出所有符合条件的路径上值的和. n<=300000. ... 
- java代码优化29个点
			通过java代码规范来优化程序,优化内存使用情况,防止内存泄露 可供程序利用的资源(内存.CPU时间.网络带宽等)是有限的,优化的目的就是让程序用尽可能少的资源完成预定的任务.优化通常包含两方面的内容 ... 
- 686. Repeated String Match 字符串重复后的子字符串查找
			[抄题]: Given two strings A and B, find the minimum number of times A has to be repeated such that B i ... 
