java 全排列 可重复_JAVA实现全排列算法(去重复)

从n个不同元素中任取m(m≤n)个元素,按照一定的顺序排列起来,叫做从n个不同元素中取出m个元素的一个排列。当m=n时所有的排列情况叫全排列。在原作者的基础上[/color][color=#000080]加了去重复排列

[code=java]package example;

import java.util.ArrayList;

import java.util.Arrays;

import java.util.HashSet;

import java.util.List;

import java.util.Set;

/**

*

* Title:全排列算法

*/

public class FullSort {

//将NUM设置为待排列数组的长度即实现全排列

private static int NUM = 4;

private static Set set = new HashSet();

/**

* 递归算法:将数据分为两部分,递归将数据从左侧移右侧实现全排列

*

* @param datas

* @param target

*/

private static void sort(List datas, List target) {

if (target.size() == NUM) {

StringBuffer sf = new StringBuffer();

for (Object obj : target){

sf.append(obj);

System.out.print(obj);

}

System.out.println();

set.add(sf.toString());

return;

}

Set sortCharacter = new HashSet();//去重复排列集合

for (int i = 0; i < datas.size(); i++) {

//去重复排列

if(sortCharacter.contains(datas.get(i))){

continue;

}else{

sortCharacter.add(datas.get(i).toString());

}

List newDatas = new ArrayList(datas);

List newTarget = new ArrayList(target);

newTarget.add(newDatas.get(i));

newDatas.remove(i);

sort(newDatas, newTarget);

}

}

public static void main(String[] args) {

String[] datas = new String[] { "a", "b", "c", "d" };

sort(Arrays.asList(datas), new ArrayList());

System.out.println(set.size());

}

}

[/code]

参考实例:[url=http://blog.csdn.net/sunyujia/article/details/4124011][/url]

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值