题目描述
给定一个 没有重复 数字的序列,返回其所有可能的全排列。
示例:
输入: [1,2,3]
输出:
[
[1,2,3],
[1,3,2],
[2,1,3],
[2,3,1],
[3,1,2],
[3,2,1]
]
解题思路
回溯法。
1 2 3
先选1,有[2,3]备选,
再选2,还有[3]备选
只剩下3,选3
完成一次排列 [1 2 3]
再选3,还有[2]备选
只剩下2,选2
完成一次排列 [1 3 2]
先选2,有[1,3]备选,
再选1,还有[3]备选
只剩下3,选3
完成一次排列 [2 1 3]
再选3,还有[1]备选
只剩下1,选1
完成一次排列 [2 3 1]
先选3,有[1 2]备选
再选1,还有2备选
只剩下2,选2
完成一次排列 [3 1 2]
再选2,还有1备选
只剩下1,选1
完成一次排列 [3 2 1]
class Solution:
def permute(self, nums: List[int]) -> List[List[int]]:
res = []
def backtrack(nums,tmp):
if not nums:
res.append(tmp)
return
for i in range(len(nums)):
backtrack(nums[:i]+nums[i+1:],tmp+[nums[i]])
backtrack(nums,[])
return res