package LeetCode;
import java.util.ArrayList;
import java.util.List;
/*
给定一个没有重复数字的序列,返回其所有可能的全排列。
示例:
输入: [1,2,3]
输出:
[
[1,2,3],
[1,3,2],
[2,1,3],
[2,3,1],
[3,1,2],
//基本思想:回溯思想进行每一层循环
*/
public class Permute {
public List<List<Integer>> permute(int[] nums) {
List<List<Integer>> result=new ArrayList<>();
List<Integer> l=new ArrayList<>();
huisu(nums,l,result);
return result;
}
public void huisu(int[] nums,List<Integer> l,List<List<Integer>> result){
if (l.size()==nums.length){
//指向新的一片地址空间使其变成不在跟随l改变而改变
result.add(new ArrayList<Integer>(l));
return;
}else {
for (int i = 0; i <nums.length ; i++) {
//判断
if (l.contains(nums[i]))continue;
l.add(nums[i]);
huisu(nums,l,result);
//退回一格
l.remove(l.size()-1);
}
}
}
public static void main(String[] args){
Permute a=new Permute();
int []b={1,2,3};
a.permute(b);
}
}
版权声明:本文为microopithecus原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。