2016-11-05 53 views
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); 
    } 
    } 
} 

回答

0

維基頁面描述了permutation algorithm to get the next lexicographic permutation,它適用於重複的元素。僞代碼:

Initialisation: 
    Start with sorted combination - here [1,2,2] 

Next permutation step: 

    Find the largest index k such that a[k] < a[k + 1]. If no such index exists, 
    the permutation is the last permutation. 

    Find the largest index l greater than k such that a[k] < a[l]. 

    Swap the value of a[k] with that of a[l]. 

    Reverse the sequence from a[k + 1] up to and including the final element a[n].