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

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

题目描述

参考代码

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;
}
相关推荐
近津薪荼44 分钟前
dfs专题10——全排列 II
算法·深度优先
Hcoco_me1 小时前
车载摄像头核心知识点结构化总结
人工智能·深度学习·数码相机·算法·机器学习·自动驾驶
紫陌涵光1 小时前
108.将有序数组转换为二叉搜索树
数据结构·算法·leetcode
iAkuya1 小时前
(leetcode)力扣100 75前K个高频元素(堆)
java·算法·leetcode
载数而行5202 小时前
算法系列2之最短路径
c语言·数据结构·c++·算法·贪心算法
逆境不可逃3 小时前
【除夕篇】LeetCode 热题 100 之 189.轮转数组
java·数据结构·算法·链表
xiaoye-duck3 小时前
《算法题讲解指南:优选算法-滑动窗口》--13 水果成篮
c++·算法
wefg13 小时前
【算法】模运算的技巧
算法
智者知已应修善业3 小时前
【冰雹猜想过程逆序输出】2025-4-19
c语言·c++·经验分享·笔记·算法
编程小白_澄映3 小时前
机器学习——特征工程
人工智能·算法·机器学习