递归实现指数型枚举(递归)

92. 递归实现指数型枚举 - AcWing题库

每个数有选和不选两种情况

我们把每个数看成每层,可以画出一个递归搜索树

叶子节点就是我们的答案

很容易写出每dfs函数

dfs传入一个u表示层数

当层数大于我们n时,去判断每个数字的选择情况,输出被选的数字

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

const int N = 20;

int n;
bool vis[N];

void dfs(int u) 
{
    if (u > n) 
    {
        for (int i = 1;i <= n;i++)
        {
            if (vis[i])
            {
                cout << i << ' ';
            }
        }
        cout << '\n';
    }else {
        vis[u] = true;
        dfs(u+1);
        
        vis[u] = false;
        dfs(u+1);
    }
}

int main() 
{
    cin >> n;
    
    dfs(1);
    
    return 0;
}
相关推荐
利刃大大15 天前
【回溯+剪枝】单词搜索,你能用递归解决吗?
剪枝·深度优先遍历·回溯·递归
利刃大大17 天前
【回溯+剪枝】优美的排列 && N皇后(含剪枝优化)
算法·二叉树·剪枝·回溯·递归
robin_suli17 天前
穷举vs暴搜vs深搜vs回溯vs剪枝系列一>单词搜索
算法·剪枝·深度优先遍历·回溯·递归
秋已杰爱1 个月前
递归练习三(决策树)
算法·决策树·递归·二叉树‘
硕风和炜2 个月前
【LeetCode: 112. 路径总和 + 二叉树 + 递归】
java·算法·leetcode·面试·二叉树·递归
Heaven6452 个月前
练8:递归
python·蓝桥杯·递归
寻找码源3 个月前
【头歌实训:递归实现斐波那契数列】
c语言·算法·递归·斐波那契
飞滕人生TYF3 个月前
斐波那契数列 相关问题 详解
java·数学·动态规划·递归·斐波那契数列
nameofworld3 个月前
前端面试笔试(五)
开发语言·前端·javascript·面试·递归