leetcode传送通道
class Solution {
List<List<Integer>> result;
List<Integer> path;
boolean[] used;
public List<List<Integer>> permuteUnique(int[] nums) {
result = new ArrayList<>();
path = new ArrayList<>();
used = new boolean[nums.length];
Arrays.sort(nums);
recur(nums);
return result;
}
private void recur(int[] nums){
// 终止条件
if(path.size() == nums.length){
result.add(new ArrayList<>(path));
return;
}
for(int i=0; i<nums.length; i++){
// 去重
// used[i-1]==false 说明同一层发生了重复
// 比较难理解的话,画个[1,1,2]的例子模拟一下
if(i>0 && nums[i]==nums[i-1] && used[i-1]==false){
continue; // 横向过滤不同索引下的相同数字
}
if(used[i]){
continue; // 纵向过滤相同索引下的相同数字
}
used[i] = true;
path.add(nums[i]);
recur(nums);
path.removeLast();
used[i] = false;
}
}
}
标签是中等,但感觉去重不简单。不理解“ used[i-1]==false ”的看这个图,感觉挺好的
.(图片来源).