Permutations II
class Solution:
"""
@param nums: A list of integers.
@return: A list of unique permutations.
"""
def permuteUnique(self, nums):
# write your code here
isVisited = [False for i in range(len(nums))]
if nums == None:
return []
result = []
self.dfs(nums, result, [], isVisited)
return result
def dfs(self, nums, result, current, isVisited):
if len(nums) == len(current):
if current not in result:
result.append(list(current))
return
for i in range(len(nums)):
if isVisited[i] == False:
isVisited[i] = True
current.append(nums[i])
self.dfs(nums, result, current, isVisited)
isVisited[i] = False
del current[-1]Last updated