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
        
相关推荐
devmoon4 分钟前
在 Paseo 测试网上获取 Coretime:On-demand 与 Bulk 的完整实操指南
开发语言·web3·区块链·测试用例·智能合约·solidity
皮卡丘不断更11 分钟前
手搓本地 RAG:我用 Python 和 Spring Boot 给 AI 装上了“实时代码监控”
人工智能·spring boot·python·ai编程
kylezhao201921 分钟前
C# 中的 SOLID 五大设计原则
开发语言·c#
千寻girling24 分钟前
Koa.js 教程 | 一份不可多得的 Node.js 的 Web 框架 Koa.js 教程
前端·后端·面试
爱打代码的小林27 分钟前
基于 MediaPipe 实现实时面部关键点检测
python·opencv·计算机视觉
程序员清风32 分钟前
北京回长沙了,简单谈谈感受!
java·后端·面试
极客小云1 小时前
【ComfyUI API 自动化利器:comfyui_xy Python 库使用详解】
网络·python·自动化·comfyui
凡人叶枫1 小时前
C++中输入、输出和文件操作详解(Linux实战版)| 从基础到项目落地,避坑指南
linux·服务器·c语言·开发语言·c++
闲人编程1 小时前
Elasticsearch搜索引擎集成指南
python·elasticsearch·搜索引擎·jenkins·索引·副本·分片
春日见1 小时前
车辆动力学:前后轮车轴
java·开发语言·驱动开发·docker·计算机外设