算法复习——排列|组合|指数枚举

递归实现指数型枚举

从 1 到 n这 n 个整数中随机选取任意多个,输出所有可能的选法,一共有多少种选择方式?

cpp 复制代码
#include <bits/stdc++.h>

using namespace std;

const int N=20;

int a[N];
bool st[N];
int ans;
int n;

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

int main()
{
    cin>>n;
    dfs(1);
    cout<<"一共有"<<ans<<"种组合方式"<<endl;
    
    return 0;
}

总结:每一个数,有选和不选,两种可能,所以一共有2n种选法,即组合方式有2n种

递归实现排列型枚举

从1~n选n个数,排列后按顺序打乱,一共有多少种排列方法,怎么排列的?

cpp 复制代码
#include <bits/stdc++.h>

using namespace std;

const int N=10;

bool st[N];
int a[N];

int n;

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

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

总结:使用布尔数组标记,是否被访问过,被访问过,就找另外的;一共有n!种组合方式,n个中选n个。

递归实现组合型枚举

从 1∼𝑛 这 n 个整数中随机选出 m 个,输出所有可能的选择方案;一共有多少个方案?

cpp 复制代码
#include <bits/stdc++.h>

using namespace std;

const int N=30;

int n,m;
bool st[N];

void dfs(int start,int x)//从那个数开始选,选择了多少个数了
{
    if(x>m)
    {
        for(int i=1;i<=n;i++)
            if(st[i]) cout<<i<<" ";
        cout<<endl;
        return ;
    }
    for(int i=start;i<=n;i++)
    {
        if(!st[i])
        {
            st[i]=true;
            dfs(i+1,x+1);
            st[i]=false;
        }
    }
}

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

总结:我们需要记录从谁开始选,然后选它后面的m个,选过的就不选了,没有选的话就选它。如果可以选够m个就输出。

通过公式可以计算方案数

相关推荐
Zephyr_023 分钟前
Leedcode算法题
java·算法
流年如夢1 小时前
栈和列队(LeetCode)
数据结构·算法·leetcode·链表·职场和发展
Hello.Reader2 小时前
算法基础(十)——分治思想把大问题拆成小问题
java·开发语言·算法
绛橘色的日落(。・∀・)ノ3 小时前
机器学习之评估与偏差方差分析
算法
消失的旧时光-19433 小时前
C语言对象模型系列(四)《Linux 内核里的 container_of 到底是什么黑魔法?》—— 一篇讲透 Linux 内核的“对象模型”核心技巧
linux·c语言·算法
AI_Ming3 小时前
从0开始学AI:层归一化,原来是这回事!
算法·ai编程
WL_Aurora4 小时前
备战蓝桥杯国赛【Day 8】
算法·蓝桥杯
智者知已应修善业4 小时前
【51单片机模拟生日蜡烛】2023-10-10
c++·经验分享·笔记·算法·51单片机
MediaTea4 小时前
Scikit-learn:从数据到结构——无监督学习的最小闭环
人工智能·学习·算法·机器学习·scikit-learn
智者知已应修善业4 小时前
【51单片机如何让LED灯从一亮到八,再从八亮到一】2023-10-13
c++·经验分享·笔记·算法·51单片机