2023-8-28 排列数字(DFS)

题目链接:排列数字

c++ 复制代码
#include <iostream>

using namespace std;

const int N = 10;

int n;

int path[N];

bool st[N];

// u 看第几个位置
void dfs(int u)
{
    if(u == n)
    {
        for(int i = 0; i < n; i ++) cout << path[i] << ' ';
        cout << endl;
        return ;
    }
    
    // 枚举当前位置可以填写哪些数
    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;
}
相关推荐
一枝小雨1 小时前
【数据结构】排序算法全解析
数据结构·算法·排序算法
略知java的景初1 小时前
深入解析十大经典排序算法原理与实现
数据结构·算法·排序算法
岁忧2 小时前
(LeetCode 每日一题) 498. 对角线遍历 (矩阵、模拟)
java·c++·算法·leetcode·矩阵·go
kyle~2 小时前
C/C++---前缀和(Prefix Sum)
c语言·c++·算法
liweiweili1262 小时前
main栈帧和func栈帧的关系
数据结构·算法
Greedy Alg2 小时前
LeetCode 560. 和为 K 的子数组
算法·leetcode·职场和发展
2501_924877213 小时前
强逆光干扰漏检率↓78%!陌讯多模态融合算法在光伏巡检的实战优化
大数据·人工智能·算法·计算机视觉·目标跟踪
2501_924877353 小时前
智慧零售漏扫率↓79%!陌讯多模态融合算法在智能收银与货架管理的实战解析
大数据·人工智能·算法·目标检测·边缘计算·零售
爱编程的鱼4 小时前
C# 数组&C# 多维数组
数据结构·算法·c#
前端开发工程师请求出战4 小时前
MCP — 让AI变得更“百搭”
算法