免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1472 | 回复: 0
打印 上一主题 下一主题

全排列算法 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-08-19 23:58 |只看该作者 |倒序浏览
全排列算法有两个比较常见的实现:递归排列和字典序排列。
(1)递归实现
从集合中依次选出每一个元素,作为排列的第一个元素,然后对剩余的元素进行全排列,如此递归处理,从而得到所有元素的全排列。算法实现如下:
    private static void perm(int nt,String[] permu) {
        // TODO Auto-generated method stub
        if(nt==n)
        {
            permu[t]="";
            for(int i=1;i= 1; i--) {
                if (A  i; k--) {
                if (A[k] > A)
                    break;
            }
            int temp = A;
            A = A[k];
            A[k] = temp;
            reverse(i + 1);
            t++;
            if (t == count) {
                for (int m = 1; m <= n; m++)
                    System.out.print(A[m]);
                System.out.println();
                break;
            }
        }
    }
    private static void reverse(int t) {
        // TODO Auto-generated method stub
        int i, j;
        for (i = t, j = n; i < j; i++, j--) {
            int temp = A;
            A = A[j];
            A[j] = temp;
        }
    }
               
               
               

本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u3/95988/showart_2032321.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP