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

递归实现指数型枚举

从 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个就输出。

通过公式可以计算方案数

相关推荐
吃杠碰小鸡1 分钟前
高中数学-数列-导数证明
前端·数学·算法
故事不长丨1 分钟前
C#线程同步:lock、Monitor、Mutex原理+用法+实战全解析
开发语言·算法·c#
long3162 分钟前
Aho-Corasick 模式搜索算法
java·数据结构·spring boot·后端·算法·排序算法
近津薪荼3 分钟前
dfs专题4——二叉树的深搜(验证二叉搜索树)
c++·学习·算法·深度优先
熊文豪11 分钟前
探索CANN ops-nn:高性能哈希算子技术解读
算法·哈希算法·cann
熊猫_豆豆28 分钟前
YOLOP车道检测
人工智能·python·算法
艾莉丝努力练剑43 分钟前
【Linux:文件】Ext系列文件系统(初阶)
大数据·linux·运维·服务器·c++·人工智能·算法
偷吃的耗子1 小时前
【CNN算法理解】:CNN平移不变性详解:数学原理与实例
人工智能·算法·cnn
dazzle2 小时前
机器学习算法原理与实践-入门(三):使用数学方法实现KNN
人工智能·算法·机器学习
那个村的李富贵2 小时前
智能炼金术:CANN加速的新材料AI设计系统
人工智能·算法·aigc·cann