[DFS]求全排列问题

问题:全排列的种树是N!,要求按字典序输出。
思路:我们可以把N个数两两建立无向边(即任意两个结点之间都有边,也就是一个N个结点的完全图),然后对每个点作为起点,分别做一次深度优先遍历,当所有点都已经标记时输出当前的遍历路径,就是其中一个排列,这里需要注意,回溯的时候需要将原先标记的点的标记取消,否则只能输出一个排列。如果要按照字典序,则需要在遍历的时候保证每次遍历都是按照结点从小到大的方式进行遍历的。

image.png

代码:

#include <iostream>
using namespace std;

void dfs(int arr[],int n,int visited[],int i,int out[])
{
    if(i == n)
    {
        for (int j = 0; j < n; ++j) {
            cout<<out[j]<<" ";
        }
        cout<<endl;
    } else{
        for (int j = 0; j < n; ++j) {
            if (visited[j] == 0)
            {
                out[i] = arr[j];
                visited[j] = 1;
                dfs(arr,n,visited,i+1,out);
                visited[j] = 0;
            }
        }
    }

}

int test_FullAranged()
{
    //freopen("in.txt","r",stdin);
    int n = 5;
    int arr[5] = {1,2,3,4,5};
    int visited[5];
    memset(visited,0, sizeof(visited));

    int out[5];

    dfs(arr,n,visited,0,out);

}
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 一些概念 数据结构就是研究数据的逻辑结构和物理结构以及它们之间相互关系,并对这种结构定义相应的运算,而且确保经过这...
    Winterfell_Z阅读 11,426评论 0 13
  • 目录 1、什么是树 2、相关术语 3、二叉树 3.1、二叉树的类型 3.2、二叉树的性质 3.3、二叉树的结构 3...
    我哈啊哈啊哈阅读 7,419评论 0 10
  • 因为之前就复习完数据结构了,所以为了保持记忆,整理了一份复习纲要,复习的时候可以看着纲要想具体内容。 树 树的基本...
    牛富贵儿阅读 12,069评论 3 10
  • 最近刷朋友圈,看到朋友发的一条消息。原来公司举办了一场游戏比赛,项目就是最近频频引起热议的某农药。完了朋友发了感慨...
    本小喵阅读 3,641评论 3 0
  • 前几天碰到一位老友,闲谈了几句,便顿觉感慨万千。我们相识于高中的校园,一别十年,却在一次培训中偶然相遇。当年,...
    残墨断梦阅读 1,270评论 0 0

友情链接更多精彩内容