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

题目描述:

从 1∼n 这 n 个整数中随机选取任意多个,输出所有可能的选择方案。

输入格式:

输入一个整数 n。

输出格式:

每行输出一种方案。

同一行内的数必须升序排列,相邻两个数用恰好 1 个空格隔开。

对于没有选任何数的方案,输出空行。

本题有自定义校验器(SPJ),各行(不同方案)之间的顺序任意。

数据范围:

1≤n≤15;

输入样例:

复制代码
3

输出样例:

复制代码
3
2
2 3
1
1 3
1 2
1 2 3

分析步骤:

第一:理清思路:

我们这道题还是DFS去求解,但是这道题目要我们求解的是指数型枚举,所以和组合型,排列型不一样。大家要明白组合和排列和指数型的区别。我们求解DFS有两种方法,一种是枚举位置;一种是枚举数字。本题采用枚举位置的方法,因为这个更简单跟容易理解。

枚举位置,我们先枚举第一个位置他有四种选择:不选,1,2,3这样我们就可以像一颗树一样去画出来。如果选了就标记一下这个数已经选过了,如果不选则放弃这个数再向后去寻找是否选择其他的数。这样我们每次都有两个选择,慢慢向下去搜索我们会发现这是一颗递归搜索树。大家可以动手画一画,看看是否和我一样。

第二:书写主函数,构建整体框架:

输入值,进入DFS这个1代表我们已经遍历到了第几个位置。书写DFS我们一定要明白,自己对于变量的定义是什么,只有明白了我们在之后的递归中才不会迷失。

cpp 复制代码
int main()
{
    cin>>n;
    dfs(1);
    return 0;
}

第三:书写DFS函数

我们一般先写结束条件,如果我们的x>n就代表所有的数都经过了选择,我们就按顺序把那些选过的标记了的输出出来就可以。

我们先假设他不选就将状态改为false再去向下递归,这样搜索一遍之后返回,再假设选择这个数再去递归,这样就可以保证所有的可能都在这里面了。

cpp 复制代码
void dfs(int x){
     if(x>n){
         for(int i = 1 ; i <= n ; i ++){
             if(st[i]) cout<<i<<" ";
         }
         cout<<endl;
         return ;
     }
    
    st[x] = false;
    dfs(x+1);
    
    st[x] = true;
    dfs(x+1);
}

代码:

cpp 复制代码
#include <iostream>
#include <cstring>
#include <algorithm>

using namespace std;

const int N = 20;
bool st[N];
int n ;

void dfs(int x){
     if(x>n){
         for(int i = 1 ; i <= n ; i ++){
             if(st[i]) cout<<i<<" ";
         }
         cout<<endl;
         return ;
     }
    
    st[x] = false;
    dfs(x+1);
    
    st[x] = true;
    dfs(x+1);
}

int main()
{
    cin>>n;
    dfs(1);
    return 0;
}

注意:递归实现排列型枚举递归实现组合型枚举;递归实现指数型枚举。这三道题目代表了DFS三大标准题型,学会这三道模板题目才有可能继续去学习更难的DFS。

相关推荐
WWZZ202529 分钟前
快速上手大模型:机器学习3(多元线性回归及梯度、向量化、正规方程)
人工智能·算法·机器学习·机器人·slam·具身感知
东方佑1 小时前
从字符串中提取重复子串的Python算法解析
windows·python·算法
西阳未落2 小时前
LeetCode——二分(进阶)
算法·leetcode·职场和发展
通信小呆呆2 小时前
以矩阵视角统一理解:外积、Kronecker 积与 Khatri–Rao 积(含MATLAB可视化)
线性代数·算法·matlab·矩阵·信号处理
FFZero12 小时前
【C++/Lua联合开发】 (二) Lua调用C++函数
c++·junit·lua
Dfreedom.2 小时前
一文掌握Python四大核心数据结构:变量、结构体、类与枚举
开发语言·数据结构·python·变量·数据类型
CoderCodingNo3 小时前
【GESP】C++四级真题 luogu-B4068 [GESP202412 四级] Recamán
开发语言·c++·算法
一个不知名程序员www3 小时前
算法学习入门---双指针(C++)
c++·算法
Maple_land3 小时前
常见Linux环境变量深度解析
linux·运维·服务器·c++·centos
Larry_Yanan3 小时前
QML学习笔记(四十四)QML与C++交互:对QML对象设置objectName
开发语言·c++·笔记·qt·学习·ui·交互