【力扣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
相关推荐
Dream it possible!18 小时前
LeetCode 面试经典 150_二叉树_二叉树展开为链表(74_114_C++_中等)
c++·leetcode·链表·面试·二叉树
做怪小疯子18 小时前
LeetCode 热题 100——双指针——三数之和
算法·leetcode·职场和发展
高山上有一只小老虎18 小时前
等差数列前n项的和
java·算法
sin_hielo18 小时前
leetcode 2536
数据结构·算法·leetcode
flashlight_hi18 小时前
LeetCode 分类刷题:203. 移除链表元素
算法·leetcode·链表
py有趣18 小时前
LeetCode算法学习之数组中的第K个最大元素
学习·算法·leetcode
吗~喽18 小时前
【LeetCode】将 x 减到 0 的最小操作数
算法·leetcode
避避风港19 小时前
Java 抽象类
java·开发语言·python
what_201819 小时前
list集合使用
数据结构·算法·list
hetao173383719 小时前
2025-11-13~14 hetao1733837的刷题记录
c++·算法