当前位置:网站首页>递归实现排列型枚举(DAY 93)
递归实现排列型枚举(DAY 93)
2022-08-02 04:22:00 【张学恒】
1:题目
把 1∼n 这 n 个整数排成一行后随机打乱顺序,输出所有可能的次序。
输入格式
一个整数 n。
输出格式
按照从小到大的顺序输出所有方案,每行 1 个。
首先,同一行相邻两个数用一个空格隔开。
其次,对于两个不同的行,对应下标的数一一比较,字典序较小的排在前面。
数据范围
1≤n≤9
输入样例:
3
输出样例:
1 2 3
1 3 2
2 1 3
2 3 1
3 1 2
3 2 1
2:代码实现
#include <cstring>
#include <vector>
#include <iostream>
#include <algorithm>
using namespace std;
int n;
vector<int> path;
void dfs(int u, int state)
{
if (u == n)
{
for (auto x : path) cout << x << ' ';
cout << endl;
return;
}
for (int i = 0; i < n; i ++ )
if (!(state >> i & 1))
{
path.push_back(i + 1);
dfs(u + 1, state + (1 << i));
path.pop_back();
}
}
int main()
{
cin >> n;
dfs(0, 0);
return 0;
}
边栏推荐
猜你喜欢
随机推荐
无主复制系统(1)-节点故障时写DB
七月阅读:《刘慈欣科幻短篇小说集Ⅰ》笔记
自定义一个下划线分词器
深度剖析-class的几个对象(utlis,component)-瀑布流-懒加载(概念,作用,原理,实现步骤)
6个月测试经验,面试跳槽狮子大开口要18K,只会点点点,给我整无语了。。
WordPress是什么?我也想用 WordPress~
falco 【1】入门
alibaba数据同步组件canal的实践整理
OpenPCDet environment configuration of 3 d object detection and demo test
互动投影墙深受展览展示喜爱的原因分析
【FreeRTOS】12 任务通知——更省资源的同步方式
关于地图GIS开发事项的一次实践整理(上)
吴恩达机器学习系列课程笔记——第八章:神经网络:表述(Neural Networks: Representation)
不会多线程还想进 BAT?精选 19 道多线程面试题,有答案边看边学
吴恩达机器学习系列课程笔记——第七章:正则化(Regularization)
已更新 联通 电信 tiny模式
复制延迟案例(4)-一致前缀读
CODESYS指针型变量编程应用(配方)
PyQt5_pyqtgraph mouse draws straight lines on line charts
Nuscenes数据集总结(下)









