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 <= numsi <= 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
        
相关推荐
2601_961845422 分钟前
高考真题试卷电子版|2025高考全科试卷分类下载
考研·面试·蓝桥杯·远程工作·程序员创富·高考
我叫黑大帅9 分钟前
前端如何竖屏固定视口背景
前端·javascript·面试
abcy07121312 分钟前
python pandas csv异步后台清洗前端优先返回成功信息
前端·python·pandas
折哥的程序人生 · 物流技术专研14 分钟前
《Java 100 天进阶之路》第95篇:消息队列基础(RocketMQ/Kafka)(2026版)
java·面试·kafka·rocketmq·java-rocketmq·求职招聘
budingxiaomoli20 分钟前
Spring日志
java·开发语言
牛油果子哥q23 分钟前
【C++ STL vector】C++ STL vector 终极精讲:动态数组底层原理、两倍扩容机制、迭代器失效、增删查改、性能剖析与工程避坑指南
开发语言·c++
颜酱29 分钟前
LangChain使用RAG 入门:让大模型读懂你的私有文档
python·langchain
不会敲代码130 分钟前
我花了三天时间,终于把 Cookie、XSS、CSRF 和浏览器存储给整明白了
javascript·面试
贩卖黄昏的熊37 分钟前
flex 布局快速梳理
开发语言·javascript·css3·html5
swipe38 分钟前
Mem0 x Agent 实战系列:分层记忆 + 三路召回,搭建真正可用的长期记忆层
前端·javascript·面试