C++ STL 快速实现全排列

目的

输入n个数,对这n个数进行全排列。

样例输入

3

3 2 1

样例输出

1 2 3

1 3 2

2 1 3

2 3 1

3 1 2

3 2 1

实现

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

const int N = 10;


int main() {
	int n, a[N];
	cin >> n;
	for (int i = 1; i <= n; i++)
		cin >> a[i];
	sort(a + 1, a + n + 1);
	do {
		for (int i = 1; i <= n; i++) {
			if (i != 1)			
				cout << " ";
			cout << a[i];
		}
		cout << endl;
	} while (next_permutation(a + 1, a + n + 1));
	return 0;
}

利用STL库里的next_permutation函数实现数组或者容器的全排列。

cpp 复制代码
next_permutation(起始地址, 终点位置); // 执行一次可以更改一次数组的内容,即改变至下一种排列
相关推荐
mit6.824几秒前
hadoop|贪心
算法
程序猿(雷霆之王)4 分钟前
C++11——线程库
开发语言·c++
a3535413824 分钟前
设计模式-桥接模式
c++·设计模式·桥接模式
2501_941805316 分钟前
在阿姆斯特丹智能港口场景中构建集装箱实时调度与高并发物流数据分析平台的工程设计实践经验分享
java·大数据·算法
panamera1211 分钟前
C++ 中 static 关键字
java·开发语言·c++
涂山小楼11 分钟前
线程join()方法的深度理解
java·前端·算法
程序炼丹师14 分钟前
stat函数的核心作用与详细解析
开发语言·c++
liulilittle18 分钟前
XDP VNP虚拟以太网关(章节:二)
linux·服务器·网络·c++·通信·xdp
gihigo199819 分钟前
LDPC码硬判决译码算法的详细解析
网络·算法
Clarence Liu19 分钟前
快慢指针问题
后端·算法