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
        
相关推荐
TE-茶叶蛋5 小时前
结合登录页-PHP基础知识点解析
android·开发语言·php
无巧不成书02185 小时前
Java包(package)全解:从定义、使用到避坑,新手零基础入门到实战
java·开发语言·package·java包
大喵桑丶5 小时前
ZABBIX7二次开发AI监控数据调取杂记
大数据·人工智能·python
WangJunXiang65 小时前
Python网络编程
开发语言·网络·python
guhy fighting5 小时前
new Map,Array.from,Object.entries的作用以及使用方法
开发语言·前端·javascript
lsx2024065 小时前
操作系统统计
开发语言
_下雨天.5 小时前
Python 网络编程
开发语言·网络·python
小樱花的樱花5 小时前
打造高效记事本:UI设计到功能实现
开发语言·c++·qt·ui
啦啦啦_99995 小时前
1. 面向对象基础
python
MgArcher5 小时前
Python高级特性:高阶函数完全指南
后端·面试