0
給定一個其中包含重複數字的數字列表。找到所有獨特的排列。排列II,刪除遞歸中的重複
For numbers [1,2,2] the unique permutations are:
[
[1,2,2],
[2,1,2],
[2,2,1]
]
在被稱爲赫普勒,爲了刪除重複的方法,我有一個if語句:
if (i != 0 && nums[i] == nums[i-1] && !set.contains(i-1)) {
continue;
}
,但我發現,如果我改變!set.contains(i - 1)
到set.contains(i-1)
它仍然是正確的( leetcode接受),但它應該是!set.contains(i - 1)
。
有人知道原因嗎?
class Solution {
/**
* @param nums: A list of integers.
* @return: A list of unique permutations.
*/
public List<List<Integer>> permuteUnique(int[] nums) {
List<List<Integer>> list = new ArrayList<List<Integer>>();
if (nums == null) {
return list;
}
if (nums.length == 0) {
list.add(new ArrayList<Integer>());
return list;
}
Arrays.sort(nums);
HashSet<Integer> set = new HashSet<Integer>();
ArrayList<Integer> current = new ArrayList<Integer>();
helper(nums, list, current, set);
return list;
}
public void helper(int [] nums,
List<List<Integer>> list,
ArrayList<Integer> current,
HashSet<Integer> set){
if(current.size() == nums.length) {
list.add(new ArrayList<Integer>(current));
return;
}
for (int i = 0; i < nums.length; i++) {
if (set.contains(i)) {
continue;
}
if (i != 0 && nums[i] == nums[i-1] && !set.contains(i-1)) {
continue;
}
current.add(nums[i]);
set.add(i);
helper(nums, list, current, set);
set.remove(i);
current.remove(current.size() - 1);
}
}
}