全排列是从从N个元素中取出M个元素,并按照一定的规则将取出元素排序,我们称之为从N个元素中取M个元素的一个排列,当M=N时,即从N个元素中取出N个元素的排列。
显然,选取的规则不同,排序的结果也不同,则可以得到不同的排列。
以最常见的全排列为例,用 S(A)表示集合 A 的元素个数。用 1、2、3、 4、5、6、7、8、9 组成数字不重复的九位数。
则每一个九位数都是集合 A 的一个元素,集合 A 中共有 9!个元素,即 S(A)=9! 如果集合 A 可以分为若干个不相交的子集,则 A 的元素等于各子集元 素之和。
下面用递归实现全排列:
//对1到9之间任意数字进行全排列
#include <iostream>
using namespace std;
const int N = 100010;
int a[N], book[N], n;
void dfs(int step)
{
//如果step == n + 1, 说明已经全部排好
if(step == n + 1)
{
for(int i = 1; i<= n; i ++ )
cout << a[i];
cout <<endl;
return; //回到最近调用dfs()函数的位置
}
for(int i = 1; i <= n; i ++)
{
if(book[i] == 0) //说明此时数字i还未排列
{
a[step] = i;
book[i] = 1;
dfs(step + 1);
book[i] = 0; // 收回才能继续使用
}
}
}
int main()
{
ios::sync_with_stdio(0);
cin.tie(0);
cin >> n;
dfs(1);
return 0;
}