【分析】
要求:给n个数,输出其递增子集 【注】:空集也是子集
在运用递归时,可以画递归搜索树来理解其过程
从前往后递归,判别:每个数要不要选,故选和不选对应两个分支,每当考虑完n个数之后,便可以得到一种方案了
以n=3为例
第一行:都不选 ,输出空集
第二行:对1,两个分支
第三行:对2,两个分支
第四行:对3,两个分支
将其转换为递归函数:考虑需要哪些参数
1. 当前是第几层,对应当前判别的是哪个数 u
2. 前面的数有没有选 bool[ ]
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
const int N = 16;
int n;
int st[N]; // 状态,记录每个位置当前的状态:0表示还没考虑,1表示选它,2表示不选它
void dfs(int u)
{
if (u > n) //第n个位置考虑完毕 输出该种结果
{
for (int i = 1; i <= n; i ++ )
if (st[i] == 1) //根据是否选择来决定输出
printf("%d ", i);
printf("\n");//一种情况输出完毕 换行
return;
}
st[u] = 2;
dfs(u + 1); // 第一个分支:不选 + 递归到下一层
st[u] = 0; // 恢复现场
st[u] = 1;
dfs(u + 1); // 第二个分支:选
st[u] = 0;
}
int main()
{
cin >> n;
dfs(1);
return 0;
}