【力扣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
相关推荐
万行1 分钟前
英语作文模板
python
韩立学长2 分钟前
【开题答辩实录分享】以《计算机类专业招聘信息爬取与查询系统设计与实现》为例进行答辩实录分享
python·scrapy·django
sheeta19984 分钟前
LeetCode 每日一题笔记 日期:2025.12.02 题目:3623. 统计梯形的数目 I
笔记·算法·leetcode
宇来风满楼4 分钟前
U-KAN复现
人工智能·深度学习·神经网络·算法·机器学习
kyle~6 分钟前
虚拟仪器LabView(VI)
c++·python·ros·labview
风萧萧19999 分钟前
Java:PPT转图片
java·python·powerpoint
洲星河ZXH10 分钟前
Java,日期时间API
java·开发语言·python
秋邱13 分钟前
AR 定位技术深度解析:从 GPS 到视觉 SLAM 的轻量化实现
开发语言·前端·网络·人工智能·python·html·ar
W_chuanqi13 分钟前
单目标实数参数优化:算法jSO
算法
Boop_wu14 分钟前
[Java EE] 多线程进阶(3) [线程安全集合类]
开发语言·windows·python