【力扣TOP100】全排列

题目要求:

思路:

可使用递归的方式。permute(nums)=对permute(nums[0:len(nums)-1])的每一个元素,尝试添加元素nums[len(nums)-1]

代码:

python 复制代码
class Solution:
    def permute(self, nums: List[int]) -> List[List[int]]:
        l=len(nums)
        if l==1:
            return [nums]
        t=self.permute(nums[0:l-1])
        ans=[]
        for v in t:
            for j in range(l-1):
                tt=v[0:j]+[nums[l-1]]+v[j:l-1]
                ans.append(tt)
            ans.append(v+[nums[l-1]])
        return ans
相关推荐
coding者在努力5 分钟前
LangChain简介,最直白的介绍
人工智能·python·语言模型·langchain
癫狂的兔子22 分钟前
【Python】【机器学习】支持向量积
python·机器学习
梦想画家23 分钟前
无前端编码,解锁Langflow无限可能:自定义Python组件开发全指南
python·智能体·langflow
-Rane36 分钟前
【C++】vector
开发语言·c++·算法
电饭叔41 分钟前
python转换字符串介绍
开发语言·windows·python
代码栈上的思考1 小时前
滑动窗口算法实战
算法
doris82041 小时前
Python 正则表达式 re.findall()
java·python·正则表达式
Mrliu__1 小时前
Python高级技巧(六):正则表达式
开发语言·python·正则表达式
Eloudy1 小时前
直接法 读书笔记 06 第6章 LU分解
人工智能·算法·ai·hpc
仰泳的熊猫1 小时前
题目1531:蓝桥杯算法提高VIP-数的划分
数据结构·c++·算法·蓝桥杯