【 算法 】全排列

对于给定的集合 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]);//交换回来
        }
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值