【力扣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
相关推荐
郝学胜-神的一滴4 分钟前
Python数据模型:深入解析及其对Python生态的影响
开发语言·网络·python·程序人生·性能优化
cici1587414 分钟前
二值化断裂裂缝的智能拼接算法
人工智能·算法·计算机视觉
麦格芬23021 分钟前
LeetCode 763 划分字母区间
算法·leetcode·职场和发展
free-elcmacom25 分钟前
机器学习进阶<8>PCA主成分分析
人工智能·python·机器学习·pca
福尔摩斯张38 分钟前
C++核心特性精讲:从C语言痛点出发,掌握现代C++编程精髓(超详细)
java·linux·c语言·数据结构·c++·驱动开发·算法
liu****1 小时前
Python 基础语法(二):程序流程控制
开发语言·python·python基础
涛涛北京1 小时前
【强化学习实验】- 策略梯度算法
人工智能·算法
大连好光景1 小时前
Python打日志
运维·python·运维开发
栀秋6661 小时前
深入浅出链表操作:从Dummy节点到快慢指针的实战精要
前端·javascript·算法
syt_biancheng1 小时前
博客系统全流程测试总结
python·selenium·测试用例·压力测试·postman