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

题出的跟白给一样,上一个写出来后稍加修改就行了

python 复制代码
class Solution:
    def __init__(self):
        self.recode=  {}

    def merge(self,lis,target):
        res = set()
        for i in lis:
            for j in range(len(i)+1):
                new_i = i[::]
                new_i.insert(j,target)
                res.add(tuple(new_i))
        return [list(i) for i in res]

        


    def permuteUnique(self, nums: List[int]) -> List[List[int]]:
        if len(nums) ==1:
            return [nums]
        res = []
        for ind,v in enumerate(nums[1:],1):
            key = tuple(nums[:ind])
            tp = self.recode.get(key)
            if not tp:
                tp = self.permuteUnique(nums[:ind])
            res = self.merge(tp,v)
        self.recode[tuple(nums)] = res
        return res
        
相关推荐
g***86691 小时前
Windows上安装Go并配置环境变量(图文步骤)
开发语言·windows·golang
Drone_xjw1 小时前
【Qt经验】QT软件打包报错 无法定位程序输入点_ZdlPvj于动态链接库 Qt5Sql.dll上
开发语言·qt
棒棒的皮皮1 小时前
【OpenCV】Python图像处理之特征提取
图像处理·python·opencv
用户576905308011 小时前
微调入门尝试:沐雪角色扮演
python·llm
ku_code_ku1 小时前
python几种包管理器的分析比较
开发语言·python·包管理器
编程小Y1 小时前
ODB和其他C++ ORM框架相比有什么优势?
开发语言·c++
2301_795167201 小时前
Python 高手编程系列一十三:现实例子 — 延迟求值属性
开发语言·windows·python
h***04771 小时前
爬虫学习案例3
爬虫·python·学习
Zfox_1 小时前
【Go】结构体、自定义类型与接口
开发语言·后端·golang