搜索与图论:深度优先搜索

搜索与图论:深度优先搜索

题目描述

参考代码

cpp 复制代码
#include <iostream>

using namespace std;

const int N = 10;

int n;
int path[N];
bool st[N];

void dfs(int u)
{
    // u == n 搜索到最后一层
    if (u == n)
    {
        for (int i = 0; i < n; i++) printf("%d ", path[i]);
        puts("");
        return;
    }
    // u < n
    for (int i = 1; i <= n; i++)
    {
        if (!st[i])
        {
            path[u] = i;
            st[i] = true;
            dfs(u + 1);
            st[i] = false;
        }
    }
}


int main()
{
    cin >> n;
    
    dfs(0);
    
    return 0;
}
相关推荐
_深海凉_4 分钟前
LeetCode热题100-找到字符串中所有字母异位词
算法·leetcode·职场和发展
木井巳9 分钟前
【递归算法】目标和
java·算法·leetcode·决策树·深度优先
旖-旎15 分钟前
哈希表(字母异位次分组)(5)
数据结构·c++·算法·leetcode·哈希算法·散列表
别或许21 分钟前
4、高数----一元函数微分学的计算
人工智能·算法·机器学习
_深海凉_27 分钟前
LeetCode热题100-最长连续序列
算法·leetcode·职场和发展
这里没有酒30 分钟前
[信息安全] AES128 加密/解密 --> state 矩阵
算法
无限进步_33 分钟前
【C++】多重继承中的虚表布局分析:D类对象为何有两个虚表?
开发语言·c++·ide·windows·git·算法·visual studio
TImCheng06091 小时前
内容运营岗位适合考哪个AI证书,与算法认证侧重点分析
人工智能·算法·内容运营
赵域Phoenix2 小时前
混沌系统是什么?
人工智能·算法·机器学习
CoderCodingNo2 小时前
【GESP】C++五、六级练习题 luogu-P1886 【模板】单调队列 / 滑动窗口
开发语言·c++·算法