leetcode hot 100 全排列

46. 全排列

已解答

中等

相关标签

相关企业

给定一个不含重复数字的数组 nums ,返回其 所有可能的全排列 。你可以 按任意顺序 返回答案。

class Solution(object):

def permute(self, nums):

"""

:type nums: List[int]

:rtype: List[List[int]]

"""

rtrt=[]

if len(nums)==0:

return []

if len(nums)==1:

return [nums]

rt = self.permute(nums[1:])

for sublist in rt:

for index,sub in enumerate(sublist):

rtrt.append(sublist[:index]+ [nums[0]] +sublist[index:])

rtrt.append(sublist+[nums[0]])

return rtrt

两种递归关系

一种是只用n-1的全排列,n可以放到n-1全排列序列的任意一个位置

第二种是 使用n次n-1的全排列,然后遍历一遍数组,每次都把遍历的数组的数放到n-1全排列的的最前面

我们使用方法一

这个最少的世界复杂度都是阶乘,最终返回的结果的数目也是阶乘的级别的

相关推荐
monster000w8 小时前
大模型微调过程
人工智能·深度学习·算法·计算机视觉·信息与通信
小小晓.8 小时前
Pinely Round 4 (Div. 1 + Div. 2)
c++·算法
SHOJYS8 小时前
学习离线处理 [CSP-J 2022 山东] 部署
数据结构·c++·学习·算法
biter down8 小时前
c++:两种建堆方式的时间复杂度深度解析
算法
zhishidi8 小时前
推荐算法优缺点及通俗解读
算法·机器学习·推荐算法
WineMonk8 小时前
WPF 力导引算法实现图布局
算法·wpf
2401_837088509 小时前
双端队列(Deque)
算法
ada7_9 小时前
LeetCode(python)108.将有序数组转换为二叉搜索树
数据结构·python·算法·leetcode
奥特曼_ it9 小时前
【机器学习】python旅游数据分析可视化协同过滤算法推荐系统(完整系统源码+数据库+开发笔记+详细部署教程)✅
python·算法·机器学习·数据分析·django·毕业设计·旅游