对于给定的集合 R = {a1,a2,a3,......,aN},其中n个元素互不相同,如何输出这些元素的所有排列?(全排列)
这里以R = {1,2,3}为例,来说明全排列的生成方法,对于这个集合,其包含3个元素,所有的排列情况有3!=6种,对于每一种排列,其第一个元素有3种选择1,2,3,对于第一个元素为1的排列,其第二个元素有2种选择2,3;第一个元素为2的排列,第二个元素也有2种选择1,3,……,依次类推,我们可以将集合的全排列与一棵多叉树对应。如下图所示:
在此树中,每一个从树根到叶子节点的路径,就对应了集合R的一个排列。通过递归算法,可以避免多叉树的构建过程,直接生成集合R的全排列,代码如下:
void Perm(int *br, int begin, int end)//br:集合,begin:集合首元素,end:集合末尾元素
{
if(begin == end)//如果首元素等于末尾元素
{
for(int i = 0;i <= end; i++ )//输出一个排列
{
cout<<br[i]<<" ";
}
}
else
{
for(int j = begin; j<= end; j++)//循环实现交换和begin+1之后的全排列
{
swap(br[j],br[bigin]);//把第i个和begin个交换
Perm(br, begin+1 , end);
swap(br[j],br[begin]);//交换回来
}
}
}