递归实现 组合问题+排列问题(DFS)

这篇具有很好参考价值的文章主要介绍了递归实现 组合问题+排列问题(DFS)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

递归实现排列型枚举

递归实现排列类型枚举 II

 递归实现组合型枚举

递归实现组合型枚举 II

递归实现指数型枚举

递归实现指数型枚举 II


递归不是循环,递归利用了系统栈,只要是函数都会被系统管理。当执行到函数地址入口时就会为函数在系统栈上分配一块内存。当函数在自己内部再次调用自己,那么系统又会给此时调用的函数再次分配内存,结果说就是层层调用。递归就是这么回事。

递归实现排列型枚举

把 1∼n 这 n 个整数排成一行后随机打乱顺序,输出所有可能的次序。

输入格式

一个整数 n。

输出格式

按照从小到大的顺序输出所有方案,每行 1 个。

首先,同一行相邻两个数用一个空格隔开。

其次,对于两个不同的行,对应下标的数一一比较,字典序较小的排在前面。

数据范围

1≤n≤9

输入样例:

3

输出样例:

1 2 3
1 3 2
2 1 3
2 3 1
3 1 2
3 2 1
#include<iostream>
using namespace std;
const int N=10;
bool st[N];
int g[N];
int n;
void dfs(int u)
{
    if(u==n)
    {
        for(int i=0;i<n;i++) cout<<g[i]<<" ";
        cout<<endl;
    }
    for(int i=1;i<=n;i++)
    {
        if(!st[i])
        {
            g[u]=i;
            st[i]=true;
            dfs(u+1);
            st[i]=false;
        }
    }
}
int main()
{
    cin>>n;
    dfs(0);
    return 0;
}

递归实现排列类型枚举 II

给定一个长度为 n 的可包含重复数字的序列,请你求出其所有不重复的全排列。

输入格式

第一行包含整数 n。

第二行包含 n 个整数。

输出格式

输出所有的不同排列,每种排列占一行。

在确定每种排列的输出顺序时,第一个数较小的先输出,第一个数相同时,第二个数较小的先输出,以此类推。

数据范围

1≤n≤9
数组中包含的元素的取值范围 [1,9]

输入样例:

3
1 1 2

输出样例:

1 1 2
1 2 1
2 1 1

 递归实现 组合问题+排列问题(DFS),深度优先,算法,图论

#include<iostream>
#include<algorithm>
using namespace std;
const int N=10;
bool st[N];
int a[N];
int g[N];
int n;
void dfs(int u)
{
    if(u==n)
    {
        for(int i=0;i<n;i++) cout<<g[i]<<" ";
        cout<<endl;
        return ;
    }
    for(int i=1;i<=n;i++)
    {
        //剪枝1
        if(!st[i])
        {
            st[i]=true;
            g[u]=a[i];
            dfs(u+1);
            st[i]=false;
            //这一步就是剪枝2 很nice
            while(a[i]==a[i+1]) i++;
        }
    }
}
int main()
{
    cin>>n;
    for(int i=1;i<=n;i++) cin>>a[i];
    sort(a+1,a+1+n);
    dfs(0);
    return 0;
}

 递归实现组合型枚举

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

输入格式

两个整数 n,m 在同一行用空格隔开。

输出格式

按照从小到大的顺序输出所有方案,每行 1 个。

首先,同一行内的数升序排列,相邻两个数用一个空格隔开。

其次,对于两个不同的行,对应下标的数一一比较,字典序较小的排在前面(例如 1 3 5 7 排在 1 3 6 8 前面)。

数据范围

n>0
0≤m≤n
n+(n−m)≤25

输入样例:

5 3

输出样例:

1 2 3 
1 2 4 
1 2 5 
1 3 4 
1 3 5 
1 4 5 
2 3 4 
2 3 5 
2 4 5 
3 4 5 

思考题:如果要求使用非递归方法,该怎么做呢?

#include<iostream>
#include<algorithm>
using namespace std;
const int N=25;
int g[N];
bool st[N];
int n,m;
void dfs(int u,int start)
{
    if(u==m)
    {
        for(int i=0;i<m;i++) cout<<g[i]<<" ";
        cout<<endl;
        return ;
    }
    for(int i=start;i<=n;i++)
    {
        if(!st[i])
        {
            
            st[i]=true;
            g[u]=i;
            dfs(u+1,i+1);
            st[i]=false;
        }
    }
}
int main()
{
    cin>>n>>m;
    dfs(0,1);
    return 0;
}

递归实现组合型枚举 II

给定一个长度为 n 的可包含重复数字的序列,从中随机选取 m 个数字,输出所有可能的选择方案。

输入格式

第一行包含两个整数 n,m。

第二行包含 n 个正整数。

输出格式

按照从小到大的顺序输出所有方案,每行 1 个。

首先,同一行内的数升序排列,相邻两个数用一个空格隔开。

其次,对于两个不同的行,对应下标的数一一比较,字典序较小的排在前面(例如1 3 5 7排在1 3 6 8前面)。

数据范围

n>0
0≤m≤n
n+(n−m)≤25
序列内所有元素均不大于 n。

输入样例:

5 3
1 2 2 3 3

输出样例:

1 2 2
1 2 3
1 3 3
2 2 3
2 3 3
#include<iostream>
#include<algorithm>
using namespace std;
const int N=25;
int a[N];
int g[N];
bool st[N];
int n,m;
void dfs(int u,int start)
{
    if(u==m)
    {
        for(int i=0;i<m;i++) cout<<g[i]<<" ";
        cout<<endl;
    }
    for(int i=start;i<=n;i++)
    {
    
      //只留下相同的数的第一个取组合 不能是 while(a[i-1]==a[i])i++;这样的话不能构成122
      //只有轮到第2个2开始排的时候需要跳过 前一个2已经恢复现场顾加上!st[i-1]可以使其跳过
        if(i != 0 && !st[i-1] && a[i-1] == a[i]) continue;
        g[u]=a[i];
        st[i] = true;
        dfs(u+1, i+1);
        st[i] = false;
       
    }
}
int main()
{
    cin>>n>>m;
    for(int i=1;i<=n;i++) cin>>a[i];
    sort(a+1,a+1+n);
    dfs(0,1);
    return 0;
}

递归实现指数型枚举

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

输入格式

输入一个整数 n。

输出格式

每行输出一种方案。

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

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

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

数据范围

1≤n≤15

输入样例

3

输出样例:


3
2
2 3
1
1 3
1 2
1 2 3
#include<iostream>
using namespace std;
const int N=16;
int g[N];
bool st[N];
int n;
void dfs(int u,int start)
{
    if(u<=n) 
    {
        for(int i=0;i<u;i++) cout<<g[i]<<" ";
        cout<<endl;
    }
    for(int i=start;i<=n;i++)
       {
           if(!st[i])
           {
               st[i]=true;
               g[u]=i;
               dfs(u+1,i+1);
               st[i]=false;
           }
       }
}
int main()
{
    cin>>n;
    dfs(0,1);
    return 0;
}
#include<iostream>
#include<algorithm>
using namespace std;
const int N=20;
int g[N];
int n;
void dfs(int u,int start)
{
    if(u<=n)
    {
        for(int i=0;i<u;i++) cout<<g[i]<<" ";
        cout<<endl;
    }
    for(int i=start;i<=n;i++)
    {
        g[u]=i;
        dfs(u+1,i+1);
    }
}
int main()
{
    cin>>n;
    dfs(0,1);
}

 

递归实现指数型枚举 II

给定一个长度为 n 的可包含重复数字的序列,从中随机选取任意多个数字,输出所有可能的选择方案。

输入格式

第一行包含一个整数 n,表示序列长度。

第二行包含 n 个正整数。

输出格式

每行输出一种方案。

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

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

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

数据范围

1≤n≤15
序列内所有元素均不大于 n。

输入样例:

3
1 2 2

输出样例:


1
2
1 2
2 2
1 2 2
#include<iostream>
#include<algorithm>
using namespace std;
const int N=16;
int g[N];
int a[N];
bool st[N];
int n;
void dfs(int u,int start)
{
    if(u<=n)
    {
        for(int i=0;i<u;i++) cout<<g[i]<<" ";
        cout<<endl;
    }
    for(int i=start;i<=n;i++)
    {
        if(!st[i])
        {
            st[i]=true;
            g[u]=a[i];
            dfs(u+1,i+1);
            st[i]=false;
            while(a[i]==a[i+1]) i++;
        }
    }
}
int main()
{
    cin>>n;
    for(int i=1;i<=n;i++) cin>>a[i];
    sort(a+1,a+1+n);
    dfs(0,1);
    return 0;
}
#include<iostream>
#include<algorithm>
using namespace std;
const int N=16;
int g[N];
int a[N];
bool st[N];
int n;
void dfs(int u,int start)
{
    if(u<=n)
    {
        for(int i=0;i<u;i++) cout<<g[i]<<" ";
        cout<<endl;
    }
    for(int i=start;i<=n;i++)
    {
       if(i!=1&&!st[i-1]&&a[i]==a[i-1]) continue;
            st[i]=true;
            g[u]=a[i];
            dfs(u+1,i+1);
            st[i]=false;
            
        
    }
}
int main()
{
    cin>>n;
    for(int i=1;i<=n;i++) cin>>a[i];
    sort(a+1,a+1+n);
    dfs(0,1);
    return 0;
}

 文章来源地址https://www.toymoban.com/news/detail-616291.html

到了这里,关于递归实现 组合问题+排列问题(DFS)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 如何实现一个简单的深度优先搜索(DFS)算法?

    前端入门之旅:探索Web开发的奇妙世界 记得点击上方或者右侧链接订阅本专栏哦 几何带你启航前端之旅 欢迎来到前端入门之旅!这个专栏是为那些对Web开发感兴趣、刚刚踏入前端领域的朋友们量身打造的。无论你是完全的新手还是有一些基础的开发者,这里都将为你提供一

    2024年02月07日
    浏览(44)
  • 力扣--深度优先算法/回溯算法47.全排列 Ⅱ

    思路分析: 使用DFS算法进行全排列,递归地尝试每个可能的排列方式。 使用 path 向量保存当前正在生成的排列,当其大小达到输入数组的大小时,将其加入结果集。 使用 numvisited 向量标记每个数字是否已经被访问过,以确保每个数字在一个排列中只使用一次。 在递归过程中

    2024年03月13日
    浏览(38)
  • AcWing 93:递归实现组合型枚举 ← DFS

    【题目来源】 https://www.acwing.com/problem/content/95/ 【题目描述】 从 1∼n 这 n 个整数中随机选出 m 个,输出所有可能的选择方案。 【输入格式】 两个整数 n,m,在同一行用空格隔开。 【输出格式】 按照从小到大的顺序输出所有方案,每行 1 个。 首先,同一行内的数升序排列,

    2024年02月14日
    浏览(34)
  • 深度优先搜索(DFS)算法

    目录 算法思想 时间复杂度和空间复杂度 算法实现 算法优缺点 应用领域 深度优先搜索(DFS)算法的思想是从图的某个起始顶点开始,沿着一条路径尽可能深入地访问图中的所有顶点,直到不能继续为止,然后返回并探索其他路径。具体而言,DFS算法使用栈数据结构来实现,

    2024年02月05日
    浏览(33)
  • 深度优先搜索(DFS)(算法笔记)

    本文内容基于《算法笔记》和官方配套练题网站“晴问算法”,是我作为小白的学习记录,如有错误还请体谅,可以留下您的宝贵意见,不胜感激。 深度优先搜索是一种枚举所有完整路径以遍历所有情况的搜索方法,总是以“深度”作为前进的。实现方式是有很多,最

    2024年02月08日
    浏览(39)
  • 259.【华为OD机试真题】特殊的加密算法(深度优先搜索(DFS)-Java&Python&C++&JS实现)

    🚀点击这里可直接跳转到本专栏,可查阅顶置最新的华为OD机试宝典~ 本专栏所有题目均包含优质解题思路,高质量解题代码(JavaPythonC++JS分别实现),详细代码讲解,助你深入学习,深度掌握!

    2024年02月21日
    浏览(39)
  • [算法日志]图论: 深度优先搜索(DFS)

    ​ 深度优先搜索算法是一种遍历图这种数据结构的算法策略,其中心思想是朝图节点的一个方向不断跳转,当该节点无下一个节点或所有方向都遍历完时,便回溯朝上一个节点的另一个方向继续遍历。这种搜索策略与回溯法有异曲同工之妙。 正因为和回溯法有相似之处,所

    2024年02月03日
    浏览(46)
  • 【数据结构与算法】图遍历算法 ( 深度优先搜索 DFS | 深度优先搜索和广度优先搜索 | 深度优先搜索基本思想 | 深度优先搜索算法步骤 | 深度优先搜索理论示例 )

    图 的 遍历 就是 对 图 中的 结点 进行遍历 , 遍历 结点 有如下两种策略 : 深度优先搜索 DFS 广度优先搜索 BFS \\\" 深度优先搜索 \\\" 英文名称是 Depth First Search , 简称 DFS ; DFS 基本思想 : 访问第一个邻接结点 : 从 起始点 出发 , 该 起始点 可能有 若干 邻接结点 , 访问 第一个 邻接结点

    2024年02月02日
    浏览(34)
  • 图的遍历(搜索)算法(深度优先算法DFS和广度优先算法BFS)

    从图的某个顶点出发访问遍图中所有顶点,且每个顶点仅被访问一次。(连通图与非连通图) 1、访问指定的起始顶点; 2、若当前访问的顶点的邻接顶点有未被访问的,则任选一个访问之;反之,退回到最近访问过的顶点;直到与起始顶点相通的全部顶点都访问完毕; 3、若

    2024年01月17日
    浏览(36)
  • 第一周算法训练(dfs)(深度优先搜索算法)

    dfs: 深度优先搜索算法 ,是一种用于遍历或 搜索树或图的算法 .沿着树的深度遍历树的节点,尽可能深的搜索树的分支。当节点v的所在边都己被探寻过,搜索将回溯到发现节点v的那条边的起始节点。这一过程一直进行到已发现从源节点可达的所有节点为止。如果还存在未被

    2024年02月20日
    浏览(40)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包