【力扣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
相关推荐
老鼠只爱大米12 小时前
LeetCode经典算法面试题 #104:二叉树的最大深度(深度优先搜索、广度优先搜索等多种实现方案详细解析)
算法·leetcode·二叉树·dfs·bfs·深度优先搜索·广度优先搜索
疯狂的喵12 小时前
分布式系统监控工具
开发语言·c++·算法
爱尔兰极光12 小时前
LeetCode热题100--两数之和
算法·leetcode·职场和发展
2301_8223827612 小时前
模板编译期排序算法
开发语言·c++·算法
m0_5613596712 小时前
嵌入式C++调试技术
开发语言·c++·算法
yuan1999712 小时前
高光谱遥感图像异常检测KRX算法Matlab实现
算法·机器学习·matlab
努力学习的小廉12 小时前
我爱学算法之—— 回溯
算法·深度优先
2301_7634724612 小时前
C++中的享元模式高级应用
开发语言·c++·算法
hcnaisd212 小时前
使用Python进行PDF文件的处理与操作
jvm·数据库·python