Q47 - Medium - 全排列 II

给定一个可包含重复数字的序列,返回所有不重复的全排列。

示例:

输入: [1,1,2]
输出:
[
[1,1,2],
[1,2,1],
[2,1,1]
]

import copy
class Solution:
    def permuteUnique(self, nums):
        """
        :type nums: List[int]
        :rtype: List[List[int]]
        """
        res = []
        nums.sort()
        self.back_track(res, nums, 0)
        return res
    
    def back_track(self, res, nums, n):
        nums = copy.deepcopy(nums)
        
        if n == len(nums)-1:
            temp = copy.deepcopy(nums)
            res.append(temp)
        else:
            for i in range(n, len(nums)):
                if i != n and nums[i] == nums[n]:
                    continue
                nums[n], nums[i] = nums[i], nums[n]
                self.back_track(res, nums, n+1)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。