【力扣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 小时前
五种常用的web加密算法
前端·算法·前端框架·web·加密·机密
知识中的海王1 小时前
js逆向入门图灵爬虫练习平台第六题
python
碳基学AI2 小时前
北京大学DeepSeek内部研讨系列:AI在新媒体运营中的应用与挑战|122页PPT下载方法
大数据·人工智能·python·算法·ai·新媒体运营·产品运营
forestsea2 小时前
Python进阶编程总结
开发语言·python·notepad++
独家回忆3643 小时前
每日算法-250410
算法
袖清暮雨3 小时前
Python刷题笔记
笔记·python·算法
熬夜造bug3 小时前
LeetCode Hot100 刷题笔记(1)—— 哈希、双指针、滑动窗口
笔记·leetcode·hot100
风掣长空3 小时前
八大排序——c++版
数据结构·算法·排序算法
乌旭4 小时前
AI芯片混战:GPU vs TPU vs NPU的算力与能效博弈
人工智能·pytorch·python·深度学习·机器学习·ai·ai编程
MinggeQingchun4 小时前
Python - 爬虫-网页抓取数据-库requests
爬虫·python·requests