AcWing94. 递归实现排列型枚举:输出1~n的全排列

题目

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

输入格式

一个整数 n n n。

输出格式

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

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

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

数据范围

1 ≤ n ≤ 9 1≤n≤9 1≤n≤9

输入样例

复制代码
3

输出样例

复制代码
1 2 3
1 3 2
2 1 3
2 3 1
3 1 2
3 2 1

思路

该问题也被称为全排列问题,所有可能的方案总数是 n ! n! n! 种。在这里,递归需要求解的问题是 "把指定的 n n n 个整数按照任意次序排列",在每次递归中,尝试把每个可用的数作为数列中的下一个数,求解 "把剩余 n − 1 n-1 n−1 个整数按照任意次序排列" 这个规模更小的子问题。

代码

cpp 复制代码
#include <cstdio>
using namespace std;

int order[15]; //按顺序依次记录被选择的整数
bool chosen[15]; //标记被选择的整数
int n;

void dfs(int cur) {
    if (cur == n + 1) { //问题边界
        for (int i = 1; i <= n; i++) {
            printf("%d ", order[i]);
        }
        puts("");
        return ;
    }
    
    for (int i = 1; i <= n; i++) {
        if (chosen[i]) continue;
        order[cur] = i;
        chosen[i] = true; //标记i被选择了
        dfs(cur + 1);
        chosen[i] = false; //回溯到上一个问题前,恢复现场
        order[cur] = 0; //本行可以省略,因为每次都会被重新赋值
    }
}

int main() {
    scanf("%d", &n);
    dfs(1);
    return 0;
}
相关推荐
KarrySmile6 小时前
Day12--HOT100--23. 合并 K 个升序链表,146. LRU 缓存,94. 二叉树的中序遍历
数据结构·链表·二叉树·递归·hot100·lru·灵茶山艾府
岁忧1 天前
(LeetCode 面试经典 150 题) 200. 岛屿数量(深度优先搜索dfs || 广度优先搜索bfs)
java·c++·leetcode·面试·go·深度优先
youzjuer1 天前
算法之二叉树
算法·深度优先
闪电麦坤952 天前
数据结构:深度优先搜索 (Depth-First Search, DFS)
数据结构·深度优先
heyCHEEMS3 天前
路径总和 Ⅱ Java
java·开发语言·深度优先
玩镜的码农小师兄3 天前
[从零开始面试算法] (11/100) LeetCode 226. 反转二叉树:递归的“镜像”魔法
c++·算法·leetcode·面试·递归·hot100
KarrySmile3 天前
网格图--Day04--网格图DFS--2684. 矩阵中移动的最大次数,1254. 统计封闭岛屿的数目,130. 被围绕的区域
矩阵·深度优先·dfs·深度优先搜索·灵茶山艾府·网格图·网格图dfs
zc.ovo4 天前
牛子图论1(二分图+连通性)
数据结构·c++·算法·深度优先·图论
KarrySmile5 天前
Day11--HOT100--25. K 个一组翻转链表,138. 随机链表的复制,148. 排序链表
数据结构·链表·递归·哈希表·分治·hot100·灵茶山艾府
何妨重温wdys5 天前
跳跃游戏(二):DFS 求解最少跳跃次数与最优路径
算法·深度优先