[47][中等][回溯] 全排列 II

题目描述

47. 全排列 II

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

示例 1:

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

示例 2:

输入:nums = [1,2,3]
输出:[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]]

提示:

  • 1 <= nums.length <= 8

  • -10 <= nums[i] <= 10

解题思路

由于数组中有重复数字, 因此不能再像[46][中等][回溯] 全排列一样, 而是需要考虑重复情况的剪枝问题.

在列举结果列表第i个位置时, 如果有多个一样的候选值, 那么只考虑其中一个就可以, 考虑其他几个得到的结果也是一样的, 因此可以剪枝.

在每一层使用一个单独的哈希表来记录本层中哪些值被搜索过, 迭代过程中遇到本层中搜索过的值, 就可以剪枝跳过了.

class Solution:
    def permuteUnique(self, nums: List[int]) -> List[List[int]]:
        def dfs(path, residual):
            if len(residual) == 0:
                results.append(path[:])

            seen = set()
            for i, num in enumerate(residual):
                if num not in seen:
                    seen.add(num)
                    path.append(num)
                    dfs(path, residual[:i] + residual[i + 1:])
                    path.pop()

        results = []
        dfs([], nums)
        return results

最后更新于

这有帮助吗?