​官方详细视频讲解​

LeetCode——46. 全排列_算法

Java实现,回溯法

class Solution {
public List<List<Integer>> permute(int[] nums) {
int len = nums.length;
List<List<Integer>> res = new ArrayList<>();
if (len == 0) return res;

Deque<Integer> path = new ArrayDeque<>(); //记录深度优先搜索的结果
boolean[] used = new boolean[nums.length]; //标记该数字是否被使用过
dfs(nums, len, 0, path, used, res);
//传入所有数字,数组长度,第0层开始递归,path,数字使用情况,最终结果
return res;

}

private void dfs(int[] nums, int len, int depth, Deque<Integer> path, boolean[] used, List<List<Integer>> res) {
if (depth == len){ //如果深度等于数组长度,则说明搜索完成
res.add(new ArrayList<Integer>(path)); //把当前状态的path拷贝到结果数组中
return;
}

for (int i = 0; i < len; i++){
if (used[i]){
continue;
}
path.addLast(nums[i]);
used[i] = true;
dfs(nums, len, depth+1,path, used, res);
//上面一段代码执行完后进行回溯
path.removeLast();
used[i] = false;
}
}


}