java and acm_用JAVA解决ACM可重复排列问题

问题:键盘输入一个仅有小写字母组成的字符串,输出以该串中任取M个字母所有排列及排列总数(输入不需要判错)。

问题的难点是:对字符串要先排序,以及有重复字符。

package main;

import java.util.ArrayList;

import java.util.Arrays;

import java.util.stream.IntStream;

import java.util.stream.Stream;

import static java.util.Collections.*;

public class Main{

public static void main(String[] args){

//int[] arr = new int[]{1, 3, 2, 5, 4, 6, 7, 1, 4, 9};

int[] arr = new int[]{1, 3, 2, 1};

IntStream stream = Arrays.stream(arr);

Stream integerStream = stream.boxed();

Integer[] integers = integerStream.toArray(Integer[]::new);

ArrayList arr2 = new ArrayList<>(Arrays.asList(integers));

sort(arr2);

do{

for (int i = 0; i

System.out.println();

}while (new Main().next_permutation(arr2, 0, arr2.size()));

}

public boolean next_permutation(ArrayList arr, int begin, int end){

if (begin == end || begin + 1 == end) {

return false;

}

for (int i=end-1; i!=begin;){

int j = i--;

if (!(arr.get(i) < arr.get(j))){

continue;

}

int k = end;

while (!(arr.get(i) < arr.get(--k)));

swap(arr, i, k);

reverse(arr.subList(j,end));

return true;

}

reverse(arr.subList(begin, end));

return false;

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值