㈠ 我希望将123、132、213、231、312、321全排列输出为1,2,3,请大侠给出算法或者java代码,谢谢!
遍历所有排列的数据:例 123 将之拆分的 ‘1’ ‘2’ ‘3‘ 用一数组存取存在的数,虽然这办法效率不高,但能你实现你的所要的效果,你按这个思想写一下吧。实在不行,我再帮你写一个
㈡ 全排列Java 源代码实现
本文将通过提供一个Java源代码实现全排列的例子,来回答关于全排列问题的提问。此代码通过递归方法遍历数组中的所有可能组合,最终打印出所有可能的全排列结果。
代码定义了一个名为Test的类,包含一个静态字符数组text和两个静态方法:permutation和printResult。permutation方法用于输出全排列,接受一个字符数组、起始位置和长度作为参数。printResult方法用于输出指定字符数组。
permutation方法首先检查当前递归层级是否小于数组长度减一。如果是,它将递归调用自身以增加当前层级,并使用一个循环对数组从当前层级的下一个元素开始的所有元素进行交换操作。交换后,permutation方法再次递归调用自身,递归层级增加,最后将原始交换操作恢复,以确保所有可能的排列都被探索。
如果当前递归层级等于数组长度减一,则表示已经到达数组末端,此时调用printResult方法输出当前排列。printResult方法通过遍历数组并打印每个元素来实现这一功能。
在main方法中,初始化字符数组text,并调用permutation方法,以从索引0开始输出全排列。最后,调用System.exit(0)确保程序在完成全排列输出后终止。
这段Java代码简洁地展示了全排列算法的实现,通过递归和交换操作来生成并打印出所有可能的排列组合,为理解和实现全排列问题提供了清晰的示例。
从n个不同元素中任取m(m≤n)个元素,按照一定的顺序排列起来,叫做从n个不同元素中取出m个元素的一个排列。当m=n时所有的排列情况叫全排列。
㈢ Java数组的全排列,里面布尔类型的数组vis[ ],在递归算法里起了什么作用,递归那块理解不了,求详细解答
不要急于看代码,你心理要知道全排列的思路,不注重思路是很多程序员易犯的错误。
全排列算法:
如果我求得固定第一位后的排列,那么全部排列就可以求出,固定第一位有10种可能,可以循环求得。
如果我求得固定第二位后的排列,固定第一位后的排列就可以求出,固定第二位有9种可能,可以循环求得。
。。。
如果我求得固定第10位后的排列,固定第9位后的排列就可以求出,固定第10位有1种可能,可以循环求得。
这很明显是递归的算法。
static void dfs(int start,int end,int num){//为全部排列的集合,start为数字的位置,end为最后一位,num多余的
if(start==end){//当前的数字位置为最后一位时,说明,一个序列已经生成
for(int i=1;i<end;i++)
System.out.print(a[i]+" ");//输出序列
System.out.println();
}
else{//序列没有生成时
for(int i=1;i<end;i++){
if(vis[i])//i是否在前面使用过
continue;//如果是直接跳过
a[start]=i;//确定start位置的数字,当start为1时就是确定第一位,有10种可能
vis[i]=true;//设置i为已使用状态,避免下一位使用i
dfs(start+1,end,num);//求得确定start位后的全部序列
vis[i]=false;//设置i为未使用状态
}
}